+1 Daumen
2,9k Aufrufe

Aufgabe:

Erstellen Sie einen Kontrollflussgraphen zu dem gegebenen Programm.

Hinweis: Einfache Anweisungen (1 Knoten + 1 Kante) können weggelassen werden, da diese die Komplexität nicht erhöhen.

public void run() {
  Map fileDetails = new Hashtable();
  BufferedReader reader = new BufferedReader(
              new FileReader(MainFrame.WATCHED_DATA));
  String dirName = reader.readLine ();
  File fileData = new File(dirName, ".vobas");
  while (dirName != null) {
      Eile[] files = new File(dirName).listFiles();
      for (File file : files) {
          FileDetail fileDetail = fileDetails.get(file.getName());
          if (fileDetail = null) {
              ScpTo.send(dirName
                  + File separatorChar
                  + file.getName ());
              fileDetails.put(file.getName(),
                  new FileDetail(new Date(), file.getName ()));
          } else if (file.lastModified() >
              fileDetail.getModificationDate().getTime()) {
          ScpTo.send(dirName
              + File separatorChar
              + file.getName ());
          fileDetails.remove (fiple.getName ());
          fileDetails.put(file.getName(),
              new FileDetail(new Date(), file.getName ()));
          }
      }
      ObjectOutput objectOutput = new ObjectOutputStream(
              new FileOutputStream(new File(dirName, ".vobas")));
      for (FileDetail fileDetail : fileDetails.values()) {
          objectOutput.writeObject(fileDetail);
      }
      objectOutput.close ();
      dirName = reader.readLine();
  }
  reader.close();
}


Avatar von

1 Antwort

0 Daumen

Antwort mit KI erzeugt

Kontrollflussgraphen Erstellung

Um den Kontrollflussgraphen für das angegebene Programm darzustellen, beginnen wir mit der Identifikation der Schlüsselpunkte und Schleifen im Code. Im Code finden wir folgende Struktur:

1. Initialisierung und Vorbereitung (Erstellung von fileDetails und reader).
2. Eine äußere while-Schleife, die läuft, solange dirName nicht null ist.
3. Innerhalb der while-Schleife wird ein Array von Files durchlaufen (for-Schleife).
4. Innerhalb der for-Schleife gibt es eine bedingte Anweisung (if-else if), um zu entscheiden, ob eine Datei gesendet und in fileDetails gespeichert oder aktualisiert wird.
5. Nach dem Beenden der for-Schleife, Serialisierung von fileDetails in eine Datei.
6. Lesen der nächsten Zeile in dirName am Ende der while-Schleife, bevor die Schleife erneut durchläuft.
7. Schließen des reader nach dem Beenden der while-Schleife.

Basierend auf dieser Struktur können wir den Kontrollflussgraphen konstruieren. Da eine grafische Darstellung hier nicht direkt möglich ist, beschreibe ich die Struktur des Graphens:

- Startknoten: Der Beginn der run Methode.

- Knoten 1: Initialisierung von fileDetails und reader.

- Knoten 2: Überprüfung der Bedingung dirName != null, führt zur äußeren while-Schleife.

- Knoten 3: Beginn der for-Schleife, Durchlauf durch das Array files.

- Knoten 4: Überprüfung der Bedingung if (fileDetail == null).

- Knoten 5: Aktionen innerhalb des if-Blocks.

- Knoten 6: Überprüfung der Bedingung im else if-Block.

- Knoten 7: Aktionen innerhalb des else if-Blocks.

- Knoten 8: Beenden der for-Schleife und Fortfahren mit der Serialisierung.

- Knoten 9: Schreiben der fileDetails in die .vobas Datei.

- Knoten 10: Lesen der nächsten dirName Zeile am Ende der while-Schleife.

- Knoten 11: Schließen des reader.

- Endknoten: Ende der run Methode.

Die Kanten des Graphens würden die Kontrollflusspfade zwischen diesen Knoten repräsentieren, einschließlich Schleifenrückführungen von Knoten 10 zu Knoten 2 für die while-Schleife und von Knoten 7/5 zu Knoten 3 für die for-Schleife.

Beachten Sie, dass wegen der Anmerkung in der Aufgabe ("Einfache Anweisungen (1 Knoten + 1 Kante) können weggelassen werden, da diese die Komplexität nicht erhöhen.") einfachere Anweisungen wie Initialisierungen und Elementzuweisungen zusammengefasst oder weggelassen wurden, um den Graphen übersichtlicher zu gestalten.
Avatar von

Ein anderes Problem?

Stell deine Frage

Willkommen bei der Stacklounge! Stell deine Frage einfach und kostenlos

x
Made by a lovely community