Newer
Older
TraceDebuggerExperiment / courseA / JHotDraw_Reverse / problem1 / JHotDraw1_Reverse_Delta.html
  1. <!DOCTYPE HTML>
  2. <html lang = "ja">
  3. <head>
  4. <title>課題A3 (接近過程抽出)</title>
  5. <meta charset = "UTF-8">
  6. <link rel = "stylesheet" type = "text/css" href = "../../../prettify.css">
  7. </head>
  8. <body>
  9. <h1>課題A3 (接近過程抽出)</h1>
  10.  
  11. <hr>
  12. <h2>接近過程抽出</h2>
  13. <p>
  14. </p>
  15.  
  16. <p>
  17. <p class = "explanation">
  18. 課題A3 (機能理解) の終了直後は下図のような状態になっているはずです.<br>
  19. まずは, DefaultDragTracker クラスのインスタンス (id = 758826749) のフィールド transformedFigures が参照している HashSet に<br>
  20. RectangleFigure クラスのインスタンス (id = 1952912699) が追加されるまでの過程を抽出して見ていきます.<br>
  21. ここで, 「実行時点の登録」ビュー上で登録している「118行目 DefaultDragTracker.mousePressed(MouseEvent)」をダブルクリックしてください.<br>
  22. すると, 現在の実行時点が DefaultDragTracker クラスの mousePressed(MouseEvent) メソッドの118行目に移ります.<br>
  23. <div class = "image"><img src = "./images/images_problem1_delta_pre/JHotDraw_1_delta_01.png" class = "threeQuartersSize"></div>
  24. <div class = "image"><img src = "./images/images_problem1_delta_pre/JHotDraw_1_delta_02.png" class = "threeQuartersSize"></div>
  25. </p>
  26. <p class = "explanation">
  27. 先ほどの操作によって, 現在は DefaultDragTracker クラスの mousePressed(MouseEvent) メソッドの118行目にいます.<br>
  28. ここで, 変数ビュー上の「呼び出し前」のメソッド名が HashSet.add(Object) であることを確認してください.<br>
  29. それを確認したら, 変数ビュー上の「呼び出し前」を開いて, 引数を右クリックしてください.<br>
  30. 右クリックすると, ポップアップメニューが出てくるので, 上の方の「オブジェクトの接近過程抽出」をクリックしてください.<br>
  31. <div class = "image"><img src = "./images/images_problem1_delta_pre/JHotDraw_1_delta_04.png" class = "threeQuartersSize"></div>
  32. </p>
  33. <p class = "explanation">
  34. 実際に「オブジェクトの接近過程抽出」を実行すると, 下図のような状態になります.<br>
  35. <div class = "image"><img src = "./images/images_problem1_delta/JHotDraw_1_delta_01.png" class = "threeQuartersSize"></div>
  36. </p>
  37. <p class = "explanation">
  38. 「オブジェクトの接近過程」ビュー上の「開始時点」をクリックしてください.<br>
  39. <div class = "image"><img src = "./images/images_problem1_delta/JHotDraw_1_delta_03.png" class = "threeQuartersSize"></div>
  40. </p>
  41. <p class = "explanation">
  42. 「オブジェクトの接近過程抽出」ビュー上の「参照先側001」から「参照先側020」までを順番にクリックしてください.<br>
  43. <div class = "image"><img src = "./images/images_problem1_delta/JHotDraw_1_delta_04.png" class = "threeQuartersSize"></div>
  44. <div class = "image"><img src = "./images/images_problem1_delta/JHotDraw_1_delta_06.png" class = "threeQuartersSize"></div>
  45. </p>
  46. <p class = "explanation">
  47. 「オブジェクトの接近過程抽出」ビュー上の「参照元側001」から「参照元側002」までを順番にクリックしてください.<br>
  48. <div class = "image"><img src = "./images/images_problem1_delta/JHotDraw_1_delta_07.png" class = "threeQuartersSize"></div>
  49. <div class = "image"><img src = "./images/images_problem1_delta/JHotDraw_1_delta_08.png" class = "threeQuartersSize"></div>
  50. </p>
  51. <p class = "explanation">
  52. 「オブジェクトの接近過程」ビュー上の「参照時点」をクリックしてください.<br>
  53. <div class = "image"><img src = "./images/images_problem1_delta/JHotDraw_1_delta_10.png" class = "threeQuartersSize"></div>
  54. </p>
  55. <p class = "explanation">
  56. ここまでで, DefaultDragTracker クラスのインスタンス (id = 758826749) のフィールド transformedFigures が参照している HashSet に<br>
  57. RectangleFigure クラスのインスタンス (id = 1952912699) が追加されるまでの過程を見てきました.<br>
  58. ここで, 課題A3の接近過程抽出は終了です.<br>
  59. 「オブジェクトの接近過程」ビューを全て閉じてください.<br>
  60. なお, デバッグ実行は終了せずにそのままの状態にしておいてください.<br>
  61. <div class = "image"><img src = "./images/images_problem1_delta/JHotDraw_1_delta_11.png" class = "threeQuartersSize"></div>
  62. </p>
  63. </p>
  64. <hr>
  65. <p>
  66. 課題A3の接近過程抽出が終了しましたら, 以下のアンケートにお答えください.
  67. <div><a href = "https://docs.google.com/forms/d/e/1FAIpQLSf4VgH2dqf0s8kn7CQhEhuLKEbUer7aDu5iCoffC6rTKgg37w/viewform" target = "_blank">アンケート回答</a></div>
  68. </p>
  69. <a href="../problem2/JHotDraw2_Reverse.html">次へ</a>
  70. </body>
  71. </html>