Struktur messen

Die Messung der strukturellen Eigenschaften einer Software ist wichtig für die Abschätzung des Entwicklungsaufwands sowie für die Wartung des Produkts. Die Struktur von Anforderungen, Design und Code hilft dabei, die Schwierigkeiten zu verstehen, die bei der Konvertierung eines Produkts in ein anderes, beim Testen eines Produkts oder bei der Vorhersage der externen Softwareattribute aus frühen internen Produktmaßnahmen auftreten.

Arten von Strukturmaßnahmen

Die Struktur der Software besteht aus drei Teilen. Sie sind -

  • Control-flow structure - Dies ist die Reihenfolge, in der Anweisungen in einem Programm ausgeführt werden.

  • Data-flow structure - Es ist das Verhalten der Daten, wenn sie mit dem Programm interagieren.

  • Data structure - Es ist die Organisation der Datenelemente in Form von Listen, Warteschlangen, Stapeln oder anderen genau definierten Strukturen zusammen mit einem Algorithmus zum Erstellen, Ändern oder Löschen.

Messung der Kontrollflussstruktur

Die Kontrollflussmaße werden normalerweise mit einem gerichteten Graphen modelliert, wobei jeder Knoten oder Punkt Programmanweisungen entspricht und jeder Bogen oder jede gerichtete Kante den Kontrollfluss von einer Anweisung zur anderen anzeigt. Diese Diagramme werden als Kontrollflussdiagramm oder gerichtetes Diagramm bezeichnet.

Wenn ‘m’ ist ein strukturelles Maß, das im Hinblick auf das Flussdiagrammmodell und das if-Programm definiert ist A ist strukturell komplexer als Programm B, dann das Maß m(A) sollte größer sein als m(B).

Datenflussstruktur messen

Der Datenfluss oder Informationsfluss kann intermodular (Informationsfluss innerhalb der Module) oder intramodular (Informationsfluss zwischen einzelnen Modulen und dem Rest des Systems) sein.

Je nachdem, wie sich Daten durch das System bewegen, können sie wie folgt klassifiziert werden:

  • Local direct flow - Wenn entweder ein Modul ein zweites Modul aufruft und Informationen an dieses weitergibt oder das aufgerufene Modul ein Ergebnis an den Aufrufer zurückgibt.

  • Local indirect flow - Wenn das aufgerufene Modul Informationen zurückgibt, die anschließend an ein zweites aufgerufenes Modul übergeben werden.

  • Global flow - Wenn Informationen über eine globale Datenstruktur von einem Modul zum anderen fließen.

Die Komplexität des Informationsflusses kann nach Henry und Kafura ausgedrückt werden als:

Information flow complexity (M) = length (M) × fan-in (M) × (fan-out (M))2

Wo,

  • Fan-in (M) - Die Anzahl der lokalen Flüsse, die bei M + enden, die Anzahl der Datenstrukturen, aus denen die Informationen von M abgerufen werden.

  • Fan–out (M) - Die Anzahl der lokalen Flüsse, die von M + ausgehen, die Anzahl der Datenstrukturen, die von M aktualisiert werden.

Datenstruktur messen

Datenstruktur kann beides sein local und global.

Locallywird der Strukturbetrag in jedem Datenelement gemessen. Ein graphentheoretischer Ansatz kann verwendet werden, um die Eigenschaften einzelner Datenstrukturen zu analysieren und zu messen. Dabei werden einfache Datentypen wie Ganzzahlen, Zeichen und Boolesche Werte als Primzahlen betrachtet und die verschiedenen Operationen berücksichtigt, mit denen wir komplexere Datenstrukturen erstellen können. Datenstrukturmaße können dann hierarchisch als Werte für die Primzahlen und Werte definiert werden, die den verschiedenen Operationen zugeordnet sind.

Globallywird eine Zählung der Gesamtzahl der benutzerdefinierten Variablen gemessen.