You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

107 lines
3.4 KiB

1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
1 year ago
  1. # Übung Debugging
  2. ### Aufgabenstellung
  3. Klonen Sie das Projekt https://gogs.informatik.hs-fulda.de/Programmiermethoden_und_werkzeuge-public/UebungDebugging.git und führen Sie die Übung entsprechend den Anweisungen in der README.md-Datei aus.
  4. ### Übung 1
  5. Starten Sie das Programm mehrfach und geben Sie verschiedene natürliche Zahlen ein.
  6. Eingabe: 45
  7. ```
  8. input: 45, Schleifenvariable: 2, Ergebnis 1
  9. input: 45, Schleifenvariable: 3, Ergebnis 0
  10. number 45 passed check: false
  11. ```
  12. Sowohl die eingegebene Zahl, als auch die Schleifenvariable und ein ganzzahliges Ergebnis werden ausgegeben.
  13. Notieren Sie die Inhalte der Variablen, nach Starten des Programms im Debug-Modus und Setzen eines Breakpoints in Zeile 35.
  14. Eingabe: 45
  15. ```
  16. int i = 2;
  17. int nextInt = 45;
  18. this //Instanz des Programms
  19. out //PrintStream Objekt
  20. ```
  21. Lassen Sie das Programm bis zum nächsten Halt weiterlaufen und notieren Sie die Inhalte der Variablen.
  22. ```
  23. int i = 3;
  24. int nextInt = 45;
  25. this //Instanz des Programms
  26. out //PrintStream Objekt
  27. ```
  28. Notieren Sie die Inhalte der Variablen, nach Starten des Programms im Debug-Modus und Eingabe der Zahl 47.
  29. ```
  30. int i = 2;
  31. int nextInt = 47;
  32. this //Instanz des Programms
  33. out //PrintStream Objekt
  34. ```
  35. Lassen Sie das Programm bis zum nächsten Halt weiterlaufen und notieren Sie die Inhalte der Variablen.
  36. ```
  37. int i = 3;
  38. int nextInt = 47;
  39. this //Instanz des Programms
  40. out //PrintStream Objekt
  41. ```
  42. Lassen Sie das Programm erneut bis zum nächsten Halt weiterlaufen und notieren Sie die Inhalte der Variablen.
  43. ```
  44. int i = 4;
  45. int nextInt = 47;
  46. this //Instanz des Programms
  47. out //PrintStream Objekt
  48. ```
  49. Die Variable "nextInt" zeigt stehts die eingegebene Zahl an. Die Variable "i" wird als Schleifenvariable verwendet, um die Zahlen von 2 bis zum eingegebenen Wert zu durchlaufen und den Rest der Division zu berechnen. Sie überprüft, ob die eingegebene Zahl durch eine andere Zahl ohne Rest teilbar ist.\
  50. Beim Starten in Debug-Modus läuft das Programm bis zum Breakpoint, durchläuft die Schleife ein Mal und gibt die Variablen aus. Deswegen ändert sich der Wert der Variable "i" immer wieder, wenn man das Programm bis zum nächsten Halt (der nächste Schleife) weiterlaufen lässt.
  51. ---
  52. ### Übung 2
  53. Starten Sie das Programm, nach Setzen eines Breakpoints in Zeile 40, im Debug-Modus und geben Sie die Zahl 45 ein. Notieren Sie den Inhalt der Variablen.
  54. ```
  55. int nextInt = 23;
  56. this //Instanz des Programms
  57. int count = 3;
  58. ```
  59. In der Debug View waren insgesammt 9 Einträge.\
  60. ```
  61. Thread[main]
  62. Uebung2.checkNumber(int)
  63. Uebung2.run()
  64. Uebung2.main(String[])
  65. Thread[Reference Handler]
  66. Thread[Finalizer]
  67. Thread[Signal Dispatcher]
  68. Thread[Notification Thread]
  69. Thread[Common-Cleaner]
  70. ```
  71. Bei der Verwendung von "step over" ist der Debugger durch die Rekursive Methode wieder in Zeile 40.\
  72. Die Anzahl der Einträge in Debug View waren insgesammt 10.\
  73. ```
  74. Thread[main]
  75. Uebung2.checkNumber(int)
  76. Uebung2.checkNumber(int)
  77. Uebund2.main(String[])
  78. Thread[Reference Handler]
  79. Thread[Finalizer]
  80. Thread[Signal Dispatcher]
  81. Thread[Notification Thread]
  82. Thread[Common-Cleaner]
  83. ```
  84. Bei der erneuten Verwendung von "step over" ist der Debugger nun in Zeile 23.\
  85. Die Anzahl der Einträge in Debug View sind nun 8.
  86. ```
  87. Thread[main]
  88. Uebung2.run()
  89. Uebung2.main(String[])
  90. Thread[Reference Handler]
  91. Thread[Finalizer]
  92. Thread[Signal Dispatcher]
  93. Thread[Notification Thread]
  94. Thread[Common-Cleaner]
  95. ```