OOAD - Guide rapide
Une histoire brève
Le paradigme orienté objet a pris sa forme à partir du concept initial d'une nouvelle approche de programmation, tandis que l'intérêt pour les méthodes de conception et d'analyse est venu beaucoup plus tard.
Le premier langage orienté objet a été Simula (Simulation de systèmes réels) qui a été développé en 1960 par des chercheurs du Centre norvégien de calcul.
En 1970, Alan Kay et son groupe de recherche chez Xerox PARK ont créé un ordinateur personnel nommé Dynabook et le premier langage de programmation orienté objet pur (OOPL) - Smalltalk, pour la programmation du Dynabook.
Dans les années 1980, Grady Booch a publié un article intitulé Object Oriented Design qui présentait principalement un design pour le langage de programmation Ada. Dans les éditions suivantes, il a étendu ses idées à une méthode complète de conception orientée objet.
Dans les années 1990, Coad a incorporé des idées comportementales aux méthodes orientées objet.
Les autres innovations importantes ont été les techniques de modélisation d'objets (OMT) de James Rumbaugh et le génie logiciel orienté objet (OOSE) d'Ivar Jacobson.
Analyse orientée objet
L'analyse orientée objet (OOA) est la procédure d'identification des exigences en matière d'ingénierie logicielle et de développement de spécifications logicielles en termes de modèle d'objet d'un système logiciel, qui comprend des objets en interaction.
La principale différence entre l'analyse orientée objet et les autres formes d'analyse est que dans l'approche orientée objet, les exigences sont organisées autour d'objets, qui intègrent à la fois des données et des fonctions. Ils sont modelés sur des objets du monde réel avec lesquels le système interagit. Dans les méthodologies d'analyse traditionnelles, les deux aspects - fonctions et données - sont considérés séparément.
Grady Booch a défini l'OOA comme suit: «L'analyse orientée objet est une méthode d'analyse qui examine les exigences du point de vue des classes et des objets trouvés dans le vocabulaire du domaine du problème» .
Les principales tâches de l'analyse orientée objet (OOA) sont:
- Identifier les objets
- Organisation des objets en créant un diagramme de modèle d'objet
- Définition des éléments internes des objets ou des attributs d'objet
- Définition du comportement des objets, c'est-à-dire des actions d'objets
- Décrire comment les objets interagissent
Les modèles couramment utilisés dans OOA sont des cas d'utilisation et des modèles d'objet.
Conception orientée objet
La conception orientée objet (OOD) implique la mise en œuvre du modèle conceptuel produit lors de l'analyse orientée objet. Dans OOD, les concepts du modèle d'analyse, qui sont indépendants de la technologie, sont mappés sur les classes d'implémentation, les contraintes sont identifiées et les interfaces sont conçues, ce qui donne un modèle pour le domaine de la solution, c'est-à-dire une description détaillée de la façon dont le système doit être construit sur des technologies concrètes.
Les détails de mise en œuvre comprennent généralement -
- Restructuration des données de classe (si nécessaire),
- Mise en œuvre de méthodes, c'est-à-dire de structures de données internes et d'algorithmes,
- Mise en œuvre du contrôle, et
- Mise en place d'associations.
Grady Booch a défini la conception orientée objet comme «une méthode de conception englobant le processus de décomposition orientée objet et une notation pour représenter les modèles logiques et physiques ainsi que statiques et dynamiques du système en cours de conception» .
Programmation orientée objet
La programmation orientée objet (POO) est un paradigme de programmation basé sur des objets (ayant à la fois des données et des méthodes) qui vise à intégrer les avantages de la modularité et de la réutilisabilité. Les objets, qui sont généralement des instances de classes, sont utilisés pour interagir les uns avec les autres pour concevoir des applications et des programmes informatiques.
Les caractéristiques importantes de la programmation orientée objet sont:
- Approche ascendante dans la conception des programmes
- Programmes organisés autour d'objets, regroupés en classes
- Focus sur les données avec des méthodes pour opérer sur les données de l'objet
- Interaction entre objets à travers des fonctions
- Réutilisation de la conception grâce à la création de nouvelles classes en ajoutant des fonctionnalités aux classes existantes
Quelques exemples de langages de programmation orientés objet sont C ++, Java, Smalltalk, Delphi, C #, Perl, Python, Ruby et PHP.
Grady Booch a défini la programmation orientée objet comme «une méthode d'implémentation dans laquelle les programmes sont organisés en collections coopératives d'objets, chacun représentant une instance d'une classe, et dont les classes sont toutes membres d'une hiérarchie de classes unies via des relations d'héritage » .
Le modèle objet visualise les éléments d'une application logicielle en termes d'objets. Dans ce chapitre, nous examinerons les concepts de base et les terminologies des systèmes orientés objet.
Objets et classes
Les concepts d'objets et de classes sont intrinsèquement liés les uns aux autres et forment le fondement du paradigme orienté objet.
Objet
Un objet est un élément du monde réel dans un environnement orienté objet qui peut avoir une existence physique ou conceptuelle. Chaque objet a -
Identité qui le distingue des autres objets du système.
État qui détermine les propriétés caractéristiques d'un objet ainsi que les valeurs des propriétés que contient l'objet.
Comportement qui représente les activités visibles de l'extérieur effectuées par un objet en termes de changements dans son état.
Les objets peuvent être modélisés en fonction des besoins de l'application. Un objet peut avoir une existence physique, comme un client, une voiture, etc. ou une existence conceptuelle immatérielle, comme un projet, un processus, etc.
Classe
Une classe représente une collection d'objets ayant les mêmes propriétés caractéristiques qui présentent un comportement commun. Il donne le plan ou la description des objets qui peuvent être créés à partir de celui-ci. La création d'un objet en tant que membre d'une classe est appelée instanciation. Ainsi, object est une instance d'une classe.
Les constituants d'une classe sont -
Un ensemble d'attributs pour les objets à instancier à partir de la classe. En général, les différents objets d'une classe ont des différences dans les valeurs des attributs. Les attributs sont souvent appelés données de classe.
Un ensemble d'opérations qui décrivent le comportement des objets de la classe. Les opérations sont également appelées fonctions ou méthodes.
Example
Considérons une classe simple, Circle, qui représente le cercle de la figure géométrique dans un espace bidimensionnel. Les attributs de cette classe peuvent être identifiés comme suit -
- x – coord, pour désigner la coordonnée x du centre
- coordonnée y, pour désigner la coordonnée y du centre
- a, pour désigner le rayon du cercle
Certaines de ses opérations peuvent être définies comme suit -
- findArea (), méthode pour calculer l'aire
- findCircumference (), méthode pour calculer la circonférence
- scale (), méthode pour augmenter ou diminuer le rayon
Lors de l'instanciation, des valeurs sont attribuées pour au moins certains des attributs. Si nous créons un objet my_circle, nous pouvons attribuer des valeurs telles que x-coord: 2, y-coord: 3 et a: 4 pour décrire son état. Or, si l'opération scale () est effectuée sur my_circle avec un facteur d'échelle de 2, la valeur de la variable a deviendra 8. Cette opération amène un changement d'état de my_circle, c'est-à-dire que l'objet a présenté un certain comportement.
Encapsulation et masquage des données
Encapsulation
L'encapsulation est le processus de liaison des attributs et des méthodes ensemble au sein d'une classe. Grâce à l'encapsulation, les détails internes d'une classe peuvent être cachés de l'extérieur. Il permet d'accéder aux éléments de la classe de l'extérieur uniquement via l'interface fournie par la classe.
Masquage des données
En règle générale, une classe est conçue de telle sorte que ses données (attributs) ne sont accessibles que par ses méthodes de classe et sont isolées d'un accès extérieur direct. Ce processus d'isolation des données d'un objet est appelé masquage de données ou masquage d'informations.
Example
Dans la classe Circle, le masquage des données peut être incorporé en rendant les attributs invisibles de l'extérieur de la classe et en ajoutant deux méthodes supplémentaires à la classe pour accéder aux données de classe, à savoir -
- setValues (), méthode pour affecter des valeurs à x-coord, y-coord et a
- getValues (), méthode pour récupérer les valeurs de x-coord, y-coord et a
Ici, les données privées de l'objet my_circle ne sont pas accessibles directement par une méthode qui n'est pas encapsulée dans la classe Circle. Il doit plutôt être accessible via les méthodes setValues () et getValues ().
Message passant
Toute application nécessite un certain nombre d'objets interagissant de manière harmonieuse. Les objets d'un système peuvent communiquer entre eux en utilisant la transmission de messages. Supposons qu'un système ait deux objets: obj1 et obj2. L'objet obj1 envoie un message à l'objet obj2, si obj1 veut que obj2 exécute l'une de ses méthodes.
Les caractéristiques de la transmission de messages sont -
- Le message passant entre deux objets est généralement unidirectionnel.
- La transmission de messages permet toutes les interactions entre les objets.
- La transmission de messages implique essentiellement l'appel de méthodes de classe.
- Les objets de différents processus peuvent être impliqués dans la transmission des messages.
Héritage
L'héritage est le mécanisme qui permet de créer de nouvelles classes à partir de classes existantes en étendant et en affinant ses capacités. Les classes existantes sont appelées les classes de base / classes parentes / super-classes, et les nouvelles classes sont appelées les classes dérivées / classes enfants / sous-classes. La sous-classe peut hériter ou dériver les attributs et méthodes de la ou des super-classes à condition que la super-classe le permette. En outre, la sous-classe peut ajouter ses propres attributs et méthodes et peut modifier n'importe laquelle des méthodes de super-classe. L'héritage définit une relation «est - une».
Example
A partir d'une classe de mammifères, un certain nombre de classes peuvent être dérivées telles que l'homme, le chat, le chien, la vache, etc. Les humains, les chats, les chiens et les vaches ont tous les caractéristiques distinctes des mammifères. De plus, chacun a ses propres caractéristiques. On peut dire qu'une vache «est - un» mammifère.
Types d'héritage
Single Inheritance - Une sous-classe dérive d'une seule super-classe.
Multiple Inheritance - Une sous-classe dérive de plusieurs super-classes.
Multilevel Inheritance - Une sous-classe dérive d'une super-classe qui à son tour est dérivée d'une autre classe et ainsi de suite.
Hierarchical Inheritance - Une classe a un certain nombre de sous-classes dont chacune peut avoir des sous-classes ultérieures, se poursuivant sur un certain nombre de niveaux, de manière à former une structure arborescente.
Hybrid Inheritance - Une combinaison d'héritage multiple et multiniveau pour former une structure en treillis.
La figure suivante présente des exemples de différents types d'héritage.
Polymorphisme
Le polymorphisme est à l'origine un mot grec qui signifie la capacité de prendre plusieurs formes. Dans le paradigme orienté objet, le polymorphisme implique l'utilisation d'opérations de différentes manières, selon l'instance sur laquelle elles opèrent. Le polymorphisme permet aux objets avec différentes structures internes d'avoir une interface externe commune. Le polymorphisme est particulièrement efficace lors de la mise en œuvre de l'héritage.
Example
Considérons deux classes, Circle et Square, chacune avec une méthode findArea (). Bien que le nom et le but des méthodes dans les classes soient identiques, l'implémentation interne, c'est-à-dire la procédure de calcul de l'aire, est différente pour chaque classe. Lorsqu'un objet de la classe Circle appelle sa méthode findArea (), l'opération trouve la zone du cercle sans aucun conflit avec la méthode findArea () de la classe Square.
Généralisation et spécialisation
La généralisation et la spécialisation représentent une hiérarchie de relations entre les classes, où les sous-classes héritent des super-classes.
Généralisation
Dans le processus de généralisation, les caractéristiques communes des classes sont combinées pour former une classe à un niveau supérieur de hiérarchie, c'est-à-dire que les sous-classes sont combinées pour former une super-classe généralisée. Il représente une relation «est - une - sorte - de». Par exemple, «la voiture est une sorte de véhicule terrestre» ou «le navire est une sorte de véhicule nautique».
Spécialisation
La spécialisation est le processus inverse de généralisation. Ici, les caractéristiques distinctives des groupes d'objets sont utilisées pour former des classes spécialisées à partir de classes existantes. On peut dire que les sous-classes sont les versions spécialisées de la super-classe.
La figure suivante montre un exemple de généralisation et de spécialisation.
Liens et association
Lien
Un lien représente une connexion à travers laquelle un objet collabore avec d'autres objets. Rumbaugh l'a défini comme «une connexion physique ou conceptuelle entre des objets». Grâce à un lien, un objet peut invoquer les méthodes ou naviguer dans un autre objet. Un lien décrit la relation entre deux ou plusieurs objets.
Association
L'association est un groupe de liens ayant une structure et un comportement communs. L'association décrit la relation entre les objets d'une ou plusieurs classes. Un lien peut être défini comme une instance d'une association.
Degré d'une association
Le degré d'une association indique le nombre de classes impliquées dans une connexion. Le degré peut être unaire, binaire ou ternaire.
UNE unary relationship connecte des objets de la même classe.
UNE binary relationship relie des objets de deux classes.
UNE ternary relationship connecte des objets de trois classes ou plus.
Rapports de cardinalité des associations
La cardinalité d'une association binaire indique le nombre d'instances participant à une association. Il existe trois types de rapports de cardinalité, à savoir -
One–to–One - Un seul objet de classe A est associé à un seul objet de classe B.
One–to–Many - Un seul objet de classe A est associé à de nombreux objets de classe B.
Many–to–Many - Un objet de classe A peut être associé à de nombreux objets de classe B et inversement un objet de classe B peut être associé à de nombreux objets de classe A.
Agrégation ou composition
L'agrégation ou la composition est une relation entre les classes par laquelle une classe peut être constituée de toute combinaison d'objets d'autres classes. Il permet aux objets d'être placés directement dans le corps d'autres classes. L'agrégation est appelée relation «partie-de» ou «a-une», avec la capacité de naviguer du tout vers ses parties. Un objet agrégé est un objet composé d'un ou plusieurs autres objets.
Example
Dans la relation, «une voiture a - un moteur», la voiture est tout l'objet ou l'ensemble et le moteur est une «partie» de la voiture. L'agrégation peut désigner -
Physical containment - Exemple, un ordinateur est composé d'un moniteur, d'un processeur, d'une souris, d'un clavier, etc.
Conceptual containment - Exemple, l'actionnaire a – une part.
Avantages du modèle objet
Maintenant que nous avons passé en revue les concepts de base relatifs à l'orientation des objets, il serait intéressant de noter les avantages que ce modèle a à offrir.
Les avantages de l'utilisation du modèle objet sont:
Cela permet un développement plus rapide des logiciels.
Il est facile à entretenir. Supposons qu'un module développe une erreur, puis un programmeur peut corriger ce module particulier, tandis que les autres parties du logiciel sont toujours opérationnelles.
Il prend en charge des mises à niveau relativement simples.
Il permet la réutilisation d'objets, de conceptions et de fonctions.
Il réduit les risques de développement, notamment lors de l'intégration de systèmes complexes.
Nous savons que la technique de modélisation orientée objet (MOO) visualise les choses dans une application en utilisant des modèles organisés autour d'objets. Toute approche de développement logiciel passe par les étapes suivantes -
- Analysis,
- Conception et
- Implementation.
En génie logiciel orienté objet, le développeur de logiciel identifie et organise l'application en termes de concepts orientés objet, avant leur représentation finale dans un langage de programmation ou des outils logiciels spécifiques.
Phases du développement logiciel orienté objet
Les principales phases du développement de logiciels utilisant une méthodologie orientée objet sont l'analyse orientée objet, la conception orientée objet et la mise en œuvre orientée objet.
Analyse orientée objet
À cette étape, le problème est formulé, les besoins des utilisateurs sont identifiés, puis un modèle est construit sur la base d'objets du monde réel. L'analyse produit des modèles sur la façon dont le système souhaité devrait fonctionner et comment il doit être développé. Les modèles n'incluent aucun détail d'implémentation afin qu'ils puissent être compris et examinés par tout expert d'application non technique.
Conception orientée objet
La conception orientée objet comprend deux étapes principales, à savoir la conception du système et la conception de l'objet.
System Design
Dans cette étape, l'architecture complète du système souhaité est conçue. Le système est conçu comme un ensemble de sous-systèmes en interaction qui à son tour est composé d'une hiérarchie d'objets en interaction, regroupés en classes. La conception du système est effectuée en fonction à la fois du modèle d'analyse du système et de l'architecture du système proposée. Ici, l'accent est mis sur les objets constituant le système plutôt que sur les processus du système.
Object Design
Dans cette phase, un modèle de conception est développé sur la base à la fois des modèles développés lors de la phase d'analyse du système et de l'architecture conçue lors de la phase de conception du système. Toutes les classes requises sont identifiées. Le concepteur décide si -
- de nouvelles classes doivent être créées à partir de zéro,
- toutes les classes existantes peuvent être utilisées dans leur forme originale, ou
- les nouvelles classes doivent être héritées des classes existantes.
Les associations entre les classes identifiées sont établies et les hiérarchies de classes sont identifiées. De plus, le développeur conçoit les détails internes des classes et leurs associations, c'est-à-dire la structure de données pour chaque attribut et les algorithmes pour les opérations.
Mise en œuvre et test orientés objet
Dans cette étape, le modèle de conception développé dans la conception d'objet est traduit en code dans un langage de programmation ou un outil logiciel approprié. Les bases de données sont créées et les exigences matérielles spécifiques sont vérifiées. Une fois le code en forme, il est testé à l'aide de techniques spécialisées pour identifier et supprimer les erreurs du code.
Principes des systèmes orientés objet
Le cadre conceptuel des systèmes orientés objet est basé sur le modèle objet. Il existe deux catégories d'éléments dans un système orienté objet -
Major Elements- Par majeur, on entend que si un modèle ne possède aucun de ces éléments, il cesse d'être orienté objet. Les quatre éléments principaux sont -
- Abstraction
- Encapsulation
- Modularity
- Hierarchy
Minor Elements- Par mineur, on entend que ces éléments sont une partie utile, mais pas indispensable du modèle objet. Les trois éléments mineurs sont -
- Typing
- Concurrency
- Persistence
Abstraction
L'abstraction signifie se concentrer sur les caractéristiques essentielles d'un élément ou d'un objet en POO, en ignorant ses propriétés étrangères ou accidentelles. Les caractéristiques essentielles sont relatives au contexte dans lequel l'objet est utilisé.
Grady Booch a défini l'abstraction comme suit -
"Une abstraction désigne les caractéristiques essentielles d'un objet qui le distinguent de tous les autres types d'objets et fournissent ainsi des limites conceptuelles clairement définies, par rapport à la perspective du spectateur."
Example - Lors de la conception d'un étudiant de classe, les attributs numéro_enrôlement, nom, cours et adresse sont inclus, tandis que des caractéristiques telles que pulse_rate et size_of_shoe sont éliminées, car elles ne sont pas pertinentes dans la perspective de l'établissement d'enseignement.
Encapsulation
L'encapsulation est le processus de liaison des attributs et des méthodes ensemble au sein d'une classe. Grâce à l'encapsulation, les détails internes d'une classe peuvent être cachés de l'extérieur. La classe a des méthodes qui fournissent des interfaces utilisateur par lesquelles les services fournis par la classe peuvent être utilisés.
Modularité
La modularité est le processus de décomposition d'un problème (programme) en un ensemble de modules afin de réduire la complexité globale du problème. Booch a défini la modularité comme -
«La modularité est la propriété d'un système qui a été décomposé en un ensemble de modules cohésifs et faiblement couplés.»
La modularité est intrinsèquement liée à l'encapsulation. La modularité peut être visualisée comme un moyen de mapper des abstractions encapsulées dans des modules physiques réels ayant une forte cohésion dans les modules et leur interaction ou couplage inter-module est faible.
Hiérarchie
Selon les termes de Grady Booch, «la hiérarchie est le classement ou l'ordre de l'abstraction». Grâce à la hiérarchie, un système peut être constitué de sous-systèmes interdépendants, qui peuvent avoir leurs propres sous-systèmes et ainsi de suite jusqu'à ce que les composants de niveau le plus petit soient atteints. Il utilise le principe de «diviser pour conquérir». La hiérarchie permet la réutilisation du code.
Les deux types de hiérarchies dans OOA sont -
“IS–A” hierarchy- Il définit la relation hiérarchique dans l'héritage, par laquelle à partir d'une super-classe, un certain nombre de sous-classes peuvent être dérivées qui peuvent à nouveau avoir des sous-classes et ainsi de suite. Par exemple, si nous dérivons une rose de classe à partir d'une fleur de classe, nous pouvons dire qu'une rose «est – une» fleur.
“PART–OF” hierarchy- Il définit la relation hiérarchique dans l'agrégation par laquelle une classe peut être composée d'autres classes. Par exemple, une fleur est composée de sépales, de pétales, d'étamines et de carpelles. On peut dire qu'un pétale est une «partie de» fleur.
Dactylographie
Selon les théories du type de données abstrait, un type est une caractérisation d'un ensemble d'éléments. En POO, une classe est visualisée comme un type ayant des propriétés distinctes de tous les autres types. Le typage est l'application de la notion selon laquelle un objet est une instance d'une classe ou d'un type unique. Il impose également que les objets de types différents ne soient généralement pas interchangés; et ne peuvent être interchangés que de manière très restreinte si cela est absolument nécessaire.
Les deux types de frappe sont -
Strong Typing - Ici, l'opération sur un objet est vérifiée au moment de la compilation, comme dans le langage de programmation Eiffel.
Weak Typing- Ici, les messages peuvent être envoyés à n'importe quelle classe. L'opération n'est vérifiée qu'au moment de l'exécution, comme dans le langage de programmation Smalltalk.
Concurrence
La concurrence dans les systèmes d'exploitation permet d'exécuter plusieurs tâches ou processus simultanément. Lorsqu'un seul processus existe dans un système, on dit qu'il n'y a qu'un seul thread de contrôle. Cependant, la plupart des systèmes ont plusieurs threads, certains actifs, certains en attente de CPU, certains suspendus et certains arrêtés. Les systèmes avec plusieurs processeurs autorisent intrinsèquement des threads de contrôle simultanés; mais les systèmes fonctionnant sur un seul processeur utilisent des algorithmes appropriés pour donner un temps processeur équitable aux threads afin de permettre la concurrence.
Dans un environnement orienté objet, il existe des objets actifs et inactifs. Les objets actifs ont des threads de contrôle indépendants qui peuvent s'exécuter simultanément avec les threads d'autres objets. Les objets actifs se synchronisent entre eux ainsi qu'avec des objets purement séquentiels.
Persistance
Un objet occupe un espace mémoire et existe pendant une période de temps donnée. Dans la programmation traditionnelle, la durée de vie d'un objet était généralement la durée de vie de l'exécution du programme qui l'a créé. Dans les fichiers ou les bases de données, la durée de vie de l'objet est plus longue que la durée du processus de création de l'objet. Cette propriété par laquelle un objet continue d'exister même après que son créateur cesse d'exister est appelée persistance.
Dans la phase d'analyse du système ou d'analyse orientée objet du développement logiciel, les exigences du système sont déterminées, les classes sont identifiées et les relations entre les classes sont identifiées.
Les trois techniques d'analyse utilisées conjointement pour l'analyse orientée objet sont la modélisation d'objets, la modélisation dynamique et la modélisation fonctionnelle.
Modélisation d'objets
La modélisation d'objets développe la structure statique du système logiciel en termes d'objets. Il identifie les objets, les classes dans lesquelles les objets peuvent être regroupés et les relations entre les objets. Il identifie également les principaux attributs et opérations qui caractérisent chaque classe.
Le processus de modélisation d'objets peut être visualisé dans les étapes suivantes -
- Identifiez les objets et regroupez-les en classes
- Identifier les relations entre les classes
- Créer un diagramme de modèle d'objet utilisateur
- Définir les attributs des objets utilisateur
- Définir les opérations à effectuer sur les classes
- Revoir le glossaire
Dynamic Modelling
After the static behavior of the system is analyzed, its behavior with respect to time and external changes needs to be examined. This is the purpose of dynamic modelling.
Dynamic Modelling can be defined as “a way of describing how an individual object responds to events, either internal events triggered by other objects, or external events triggered by the outside world”.
The process of dynamic modelling can be visualized in the following steps −
- Identify states of each object
- Identify events and analyze the applicability of actions
- Construct dynamic model diagram, comprising of state transition diagrams
- Express each state in terms of object attributes
- Validate the state–transition diagrams drawn
Functional Modelling
Functional Modelling is the final component of object-oriented analysis. The functional model shows the processes that are performed within an object and how the data changes as it moves between methods. It specifies the meaning of the operations of object modelling and the actions of dynamic modelling. The functional model corresponds to the data flow diagram of traditional structured analysis.
The process of functional modelling can be visualized in the following steps −
- Identify all the inputs and outputs
- Construct data flow diagrams showing functional dependencies
- State the purpose of each function
- Identify constraints
- Specify optimization criteria
Structured Analysis vs. Object Oriented Analysis
The Structured Analysis/Structured Design (SASD) approach is the traditional approach of software development based upon the waterfall model. The phases of development of a system using SASD are −
- Feasibility Study
- Requirement Analysis and Specification
- System Design
- Implementation
- Post-implementation Review
Now, we will look at the relative advantages and disadvantages of structured analysis approach and object-oriented analysis approach.
Advantages/Disadvantages of Object Oriented Analysis
Advantages | Disadvantages |
---|---|
Focuses on data rather than the procedures as in Structured Analysis. | Functionality is restricted within objects. This may pose a problem for systems which are intrinsically procedural or computational in nature. |
The principles of encapsulation and data hiding help the developer to develop systems that cannot be tampered by other parts of the system. | It cannot identify which objects would generate an optimal system design. |
The principles of encapsulation and data hiding help the developer to develop systems that cannot be tampered by other parts of the system. | The object-oriented models do not easily show the communications between the objects in the system. |
It allows effective management of software complexity by the virtue of modularity. | All the interfaces between the objects cannot be represented in a single diagram. |
It can be upgraded from small to large systems at a greater ease than in systems following structured analysis. |
Advantages/Disadvantages of Structured Analysis
Advantages | Disadvantages |
---|---|
As it follows a top-down approach in contrast to bottom-up approach of object-oriented analysis, it can be more easily comprehended than OOA. | In traditional structured analysis models, one phase should be completed before the next phase. This poses a problem in design, particularly if errors crop up or requirements change. |
It is based upon functionality. The overall purpose is identified and then functional decomposition is done for developing the software. The emphasis not only gives a better understanding of the system but also generates more complete systems. | The initial cost of constructing the system is high, since the whole system needs to be designed at once leaving very little option to add functionality later. |
The specifications in it are written in simple English language, and hence can be more easily analyzed by non-technical personnel. | It does not support reusability of code. So, the time and cost of development is inherently high. |
The dynamic model represents the time–dependent aspects of a system. It is concerned with the temporal changes in the states of the objects in a system. The main concepts are −
State, which is the situation at a particular condition during the lifetime of an object.
Transition, a change in the state
Event, an occurrence that triggers transitions
Action, an uninterrupted and atomic computation that occurs due to some event, and
Concurrency of transitions.
A state machine models the behavior of an object as it passes through a number of states in its lifetime due to some events as well as the actions occurring due to the events. A state machine is graphically represented through a state transition diagram.
States and State Transitions
State
The state is an abstraction given by the values of the attributes that the object has at a particular time period. It is a situation occurring for a finite time period in the lifetime of an object, in which it fulfils certain conditions, performs certain activities, or waits for certain events to occur. In state transition diagrams, a state is represented by rounded rectangles.
Parts of a state
Name − A string differentiates one state from another. A state may not have any name.
Entry/Exit Actions − It denotes the activities performed on entering and on exiting the state.
Internal Transitions − The changes within a state that do not cause a change in the state.
Sub–states − States within states.
Initial and Final States
The default starting state of an object is called its initial state. The final state indicates the completion of execution of the state machine. The initial and the final states are pseudo-states, and may not have the parts of a regular state except name. In state transition diagrams, the initial state is represented by a filled black circle. The final state is represented by a filled black circle encircled within another unfilled black circle.
Transition
A transition denotes a change in the state of an object. If an object is in a certain state when an event occurs, the object may perform certain activities subject to specified conditions and change the state. In this case, a state−transition is said to have occurred. The transition gives the relationship between the first state and the new state. A transition is graphically represented by a solid directed arc from the source state to the destination state.
The five parts of a transition are −
Source State − The state affected by the transition.
Event Trigger − The occurrence due to which an object in the source state undergoes a transition if the guard condition is satisfied.
Guard Condition − A Boolean expression which if True, causes a transition on receiving the event trigger.
Action − An un-interruptible and atomic computation that occurs on the source object due to some event.
Target State − The destination state after completion of transition.
Example
Suppose a person is taking a taxi from place X to place Y. The states of the person may be: Waiting (waiting for taxi), Riding (he has got a taxi and is travelling in it), and Reached (he has reached the destination). The following figure depicts the state transition.
Events
Events are some occurrences that can trigger state transition of an object or a group of objects. Events have a location in time and space but do not have a time period associated with it. Events are generally associated with some actions.
Examples of events are mouse click, key press, an interrupt, stack overflow, etc.
Events that trigger transitions are written alongside the arc of transition in state diagrams.
Example
Considering the example shown in the above figure, the transition from Waiting state to Riding state takes place when the person gets a taxi. Likewise, the final state is reached, when he reaches the destination. These two occurrences can be termed as events Get_Taxi and Reach_Destination. The following figure shows the events in a state machine.
External and Internal Events
External events are those events that pass from a user of the system to the objects within the system. For example, mouse click or key−press by the user are external events.
Internal events are those that pass from one object to another object within a system. For example, stack overflow, a divide error, etc.
Deferred Events
Deferred events are those which are not immediately handled by the object in the current state but are lined up in a queue so that they can be handled by the object in some other state at a later time.
Event Classes
Event class indicates a group of events with common structure and behavior. As with classes of objects, event classes may also be organized in a hierarchical structure. Event classes may have attributes associated with them, time being an implicit attribute. For example, we can consider the events of departure of a flight of an airline, which we can group into the following class −
Flight_Departs (Flight_No, From_City, To_City, Route)
Actions
Activity
Activity is an operation upon the states of an object that requires some time period. They are the ongoing executions within a system that can be interrupted. Activities are shown in activity diagrams that portray the flow from one activity to another.
Action
An action is an atomic operation that executes as a result of certain events. By atomic, it is meant that actions are un-interruptible, i.e., if an action starts executing, it runs into completion without being interrupted by any event. An action may operate upon an object on which an event has been triggered or on other objects that are visible to this object. A set of actions comprise an activity.
Entry and Exit Actions
Entry action is the action that is executed on entering a state, irrespective of the transition that led into it.
Likewise, the action that is executed while leaving a state, irrespective of the transition that led out of it, is called an exit action.
Scenario
Scenario is a description of a specified sequence of actions. It depicts the behavior of objects undergoing a specific action series. The primary scenarios depict the essential sequences and the secondary scenarios depict the alternative sequences.
Diagrams for Dynamic Modelling
There are two primary diagrams that are used for dynamic modelling −
Interaction Diagrams
Interaction diagrams describe the dynamic behavior among different objects. It comprises of a set of objects, their relationships, and the message that the objects send and receive. Thus, an interaction models the behavior of a group of interrelated objects. The two types of interaction diagrams are −
Sequence Diagram − It represents the temporal ordering of messages in a tabular manner.
Collaboration Diagram − It represents the structural organization of objects that send and receive messages through vertices and arcs.
State Transition Diagram
State transition diagrams or state machines describe the dynamic behavior of a single object. It illustrates the sequences of states that an object goes through in its lifetime, the transitions of the states, the events and conditions causing the transition and the responses due to the events.
Concurrency of Events
In a system, two types of concurrency may exist. They are −
System Concurrency
Here, concurrency is modelled in the system level. The overall system is modelled as the aggregation of state machines, where each state machine executes concurrently with others.
Concurrency within an Object
Here, an object can issue concurrent events. An object may have states that are composed of sub-states, and concurrent events may occur in each of the sub-states.
Concepts related to concurrency within an object are as follows −
Simple and Composite States
A simple state has no sub-structure. A state that has simpler states nested inside it is called a composite state. A sub-state is a state that is nested inside another state. It is generally used to reduce the complexity of a state machine. Sub-states can be nested to any number of levels.
Composite states may have either sequential sub-states or concurrent sub-states.
Sequential Sub-states
In sequential sub-states, the control of execution passes from one sub-state to another sub-state one after another in a sequential manner. There is at most one initial state and one final state in these state machines.
The following figure illustrates the concept of sequential sub-states.
Concurrent Sub-states
In concurrent sub-states, the sub-states execute in parallel, or in other words, each state has concurrently executing state machines within it. Each of the state machines has its own initial and final states. If one concurrent sub-state reaches its final state before the other, control waits at its final state. When all the nested state machines reach their final states, the sub-states join back to a single flow.
The following figure shows the concept of concurrent sub-states.
Functional Modelling gives the process perspective of the object-oriented analysis model and an overview of what the system is supposed to do. It defines the function of the internal processes in the system with the aid of Data Flow Diagrams (DFDs). It depicts the functional derivation of the data values without indicating how they are derived when they are computed, or why they need to be computed.
Data Flow Diagrams
Functional Modelling is represented through a hierarchy of DFDs. The DFD is a graphical representation of a system that shows the inputs to the system, the processing upon the inputs, the outputs of the system as well as the internal data stores. DFDs illustrate the series of transformations or computations performed on the objects or the system, and the external controls and objects that affect the transformation.
Rumbaugh et al. have defined DFD as, “A data flow diagram is a graph which shows the flow of data values from their sources in objects through processes that transform them to their destinations on other objects.”
The four main parts of a DFD are −
- Processes,
- Data Flows,
- Actors, and
- Data Stores.
The other parts of a DFD are −
- Constraints, and
- Control Flows.
Features of a DFD
Processes
Processes are the computational activities that transform data values. A whole system can be visualized as a high-level process. A process may be further divided into smaller components. The lowest-level process may be a simple function.
Representation in DFD − A process is represented as an ellipse with its name written inside it and contains a fixed number of input and output data values.
Example − The following figure shows a process Compute_HCF_LCM that accepts two integers as inputs and outputs their HCF (highest common factor) and LCM (least common multiple).
Data Flows
Data flow represents the flow of data between two processes. It could be between an actor and a process, or between a data store and a process. A data flow denotes the value of a data item at some point of the computation. This value is not changed by the data flow.
Representation in DFD − A data flow is represented by a directed arc or an arrow, labelled with the name of the data item that it carries.
In the above figure, Integer_a and Integer_b represent the input data flows to the process, while L.C.M. and H.C.F. are the output data flows.
A data flow may be forked in the following cases −
The output value is sent to several places as shown in the following figure. Here, the output arrows are unlabelled as they denote the same value.
The data flow contains an aggregate value, and each of the components is sent to different places as shown in the following figure. Here, each of the forked components is labelled.
Actors
Actors are the active objects that interact with the system by either producing data and inputting them to the system, or consuming data produced by the system. In other words, actors serve as the sources and the sinks of data.
Representation in DFD − An actor is represented by a rectangle. Actors are connected to the inputs and outputs and lie on the boundary of the DFD.
Example − The following figure shows the actors, namely, Customer and Sales_Clerk in a counter sales system.
Data Stores
Data stores are the passive objects that act as a repository of data. Unlike actors, they cannot perform any operations. They are used to store data and retrieve the stored data. They represent a data structure, a disk file, or a table in a database.
Representation in DFD- Un magasin de données est représenté par deux lignes parallèles contenant le nom du magasin de données. Chaque magasin de données est connecté à au moins un processus. Les flèches d'entrée contiennent des informations permettant de modifier le contenu de la banque de données, tandis que les flèches de sortie contiennent des informations extraites de la banque de données. Lorsqu'une partie des informations doit être récupérée, la flèche de sortie est étiquetée. Une flèche non étiquetée indique une récupération complète des données. Une flèche bidirectionnelle implique à la fois la récupération et la mise à jour.
Example- La figure suivante montre un magasin de données, Sales_Record, qui stocke les détails de toutes les ventes. L'entrée dans le magasin de données comprend les détails des ventes tels que l'article, le montant de facturation, la date, etc. Pour trouver les ventes moyennes, le processus récupère les enregistrements de ventes et calcule la moyenne.
Contraintes
Les contraintes spécifient les conditions ou restrictions qui doivent être satisfaites au fil du temps. Ils permettent d'ajouter de nouvelles règles ou de modifier des règles existantes. Des contraintes peuvent apparaître dans les trois modèles d'analyse orientée objet.
Dans la modélisation d'objets, les contraintes définissent la relation entre les objets. Ils peuvent également définir la relation entre les différentes valeurs qu'un objet peut prendre à différents moments.
Dans la modélisation dynamique, les contraintes définissent la relation entre les états et les événements de différents objets.
Dans la modélisation fonctionnelle, les contraintes définissent les restrictions sur les transformations et les calculs.
Representation - Une contrainte est rendue sous forme de chaîne entre accolades.
Example- La figure suivante montre une partie du DFD pour le calcul du salaire des employés d'une entreprise qui a décidé de donner des primes à tous les employés du service commercial et d'augmenter le salaire de tous les employés du service RH. On voit que la contrainte {Dept: Sales} fait que l'incitation ne soit calculée que si le département est commercial et que la contrainte {Dept: HR} fait que l'incrément ne soit calculé que si le département est HR.
Contrôle des flux
Un processus peut être associé à une certaine valeur booléenne et n'est évalué que si la valeur est vraie, bien qu'il ne s'agisse pas d'une entrée directe dans le processus. Ces valeurs booléennes sont appelées les flux de contrôle.
Representation in DFD - Les flux de contrôle sont représentés par un arc en pointillé du processus produisant la valeur booléenne au processus contrôlé par eux.
Example- La figure suivante représente un DFD pour la division arithmétique. Le diviseur est testé pour non nul. S'il n'est pas égal à zéro, le flux de contrôle OK a une valeur True et par la suite, le processus de division calcule le quotient et le reste.
Développement du modèle DFD d'un système
Afin de développer le modèle DFD d'un système, une hiérarchie de DFD est construite. Le DFD de niveau supérieur comprend un processus unique et les acteurs interagissant avec lui.
À chaque niveau inférieur successif, des détails supplémentaires sont progressivement inclus. Un processus est décomposé en sous-processus, les flux de données parmi les sous-processus sont identifiés, les flux de contrôle sont déterminés et les magasins de données sont définis. Lors de la décomposition d'un processus, le flux de données entrant ou sortant du processus doit correspondre au flux de données au niveau suivant de DFD.
Example- Considérons un système logiciel, Wholesaler Software, qui automatise les transactions d'un magasin de gros. Le magasin vend en gros et a une clientèle composée de commerçants et de propriétaires de magasins de détail. Chaque client est invité à s'inscrire avec ses coordonnées et reçoit un code client unique, C_Code. Une fois la vente effectuée, la boutique enregistre ses coordonnées et envoie les marchandises pour expédition. Chaque année, la boutique distribue des cadeaux de Noël à ses clients, qui se composent d'une pièce d'argent ou d'une pièce d'or en fonction du total des ventes et de la décision du propriétaire.
Le modèle fonctionnel du logiciel de gros est indiqué ci-dessous. La figure ci-dessous montre le DFD de niveau supérieur. Il montre le logiciel comme un processus unique et les acteurs qui interagissent avec lui.
Les acteurs du système sont -
- Customers
- Salesperson
- Proprietor
Dans le DFD de niveau suivant, comme le montre la figure suivante, les principaux processus du système sont identifiés, les magasins de données sont définis et l'interaction des processus avec les acteurs, et les magasins de données sont établis.
Dans le système, trois processus peuvent être identifiés, qui sont -
- Enregistrer les clients
- Ventes de processus
- Vérifier les cadeaux
Les magasins de données qui seront nécessaires sont -
- Détails du client
- Détails des ventes
- Détails du cadeau
La figure suivante montre les détails du processus Enregistrer un client. Il comporte trois processus: vérifier les détails, générer le code C et mettre à jour les détails du client. Lorsque les coordonnées du client sont saisies, elles sont vérifiées. Si les données sont correctes, C_Code est généré et le magasin de données Détails du client est mis à jour.
La figure suivante montre l'extension du processus Vérifier les dons. Il comporte deux processus, trouver les ventes totales et décider du type de pièce cadeau. Le processus Rechercher les ventes totales calcule les ventes totales annuelles correspondant à chaque client et enregistre les données. En prenant cet enregistrement et la décision du propriétaire comme entrées, les pièces-cadeaux sont attribuées via le processus Décider le type de pièces-cadeaux.
Avantages et inconvénients du DFD
Avantages | Désavantages |
---|---|
Les DFD décrivent les limites d'un système et sont donc utiles pour décrire la relation entre les objets externes et les processus au sein du système. | Les DFD prennent beaucoup de temps à créer, ce qui peut ne pas être réalisable à des fins pratiques. |
Ils aident les utilisateurs à avoir une connaissance du système. | Les DFD ne fournissent aucune information sur le comportement dépendant du temps, c'est-à-dire qu'ils ne spécifient pas quand les transformations sont effectuées. |
La représentation graphique sert de modèle aux programmeurs pour développer un système. | Ils n'éclairent pas la fréquence des calculs ni les raisons des calculs. |
Les DFD fournissent des informations détaillées sur les processus du système. | La préparation des DFD est un processus complexe qui nécessite une expertise considérable. En outre, il est difficile pour une personne non technique de comprendre. |
Ils sont utilisés dans le cadre de la documentation du système. | La méthode de préparation est subjective et laisse une large marge de manœuvre pour être imprécise. |
Relation entre les modèles objet, dynamique et fonctionnel
Le modèle objet, le modèle dynamique et le modèle fonctionnel sont complémentaires pour une analyse complète orientée objet.
La modélisation d'objets développe la structure statique du système logiciel en termes d'objets. Ainsi, il montre les «faiseurs» d'un système.
La modélisation dynamique développe le comportement temporel des objets en réponse à des événements externes. Il montre les séquences d'opérations effectuées sur les objets.
Le modèle fonctionnel donne un aperçu de ce que le système doit faire.
Modèle fonctionnel et modèle objet
Les quatre parties principales d'un modèle fonctionnel en termes de modèle objet sont:
Process - Les processus impliquent les méthodes des objets à implémenter.
Actors - Les acteurs sont les objets du modèle objet.
Data Stores - Ce sont soit des objets dans le modèle d'objet, soit des attributs d'objets.
Data Flows- Les flux de données vers ou depuis les acteurs représentent des opérations sur ou par des objets. Les flux de données vers ou depuis les magasins de données représentent des requêtes ou des mises à jour.
Modèle fonctionnel et modèle dynamique
Le modèle dynamique indique quand les opérations sont effectuées, tandis que le modèle fonctionnel indique comment elles sont effectuées et quels arguments sont nécessaires. Les acteurs étant des objets actifs, le modèle dynamique doit spécifier quand il agit. Les magasins de données sont des objets passifs et ils ne répondent qu'aux mises à jour et aux requêtes; par conséquent, le modèle dynamique n'a pas besoin de spécifier quand ils agissent.
Modèle d'objet et modèle dynamique
Le modèle dynamique montre l'état des objets et les opérations effectuées sur les occurrences d'événements et les changements d'états ultérieurs. L'état de l'objet suite aux modifications est affiché dans le modèle d'objet.
Le langage de modélisation unifié (UML) est un langage graphique pour OOAD qui donne un moyen standard d'écrire le plan d'un système logiciel. Il aide à visualiser, spécifier, construire et documenter les artefacts d'un système orienté objet. Il est utilisé pour décrire les structures et les relations dans un système complexe.
Bref historique
Il a été développé dans les années 1990 comme une fusion de plusieurs techniques, notamment la technique OOAD par Grady Booch, OMT (Object Modeling Technique) par James Rumbaugh et OOSE (Object Oriented Software Engineering) par Ivar Jacobson. UML a tenté de standardiser les modèles sémantiques, les notations syntaxiques et les diagrammes d'OOAD.
Systèmes et modèles en UML
System- Un ensemble d'éléments organisés pour atteindre certains objectifs forme un système. Les systèmes sont souvent divisés en sous-systèmes et décrits par un ensemble de modèles.
Model - Le modèle est une abstraction simplifiée, complète et cohérente d'un système, créée pour une meilleure compréhension du système.
View - Une vue est une projection du modèle d'un système à partir d'une perspective spécifique.
Modèle conceptuel d'UML
Le modèle conceptuel d'UML comprend trois éléments majeurs -
- Blocs de construction de base
- Rules
- Mécanismes communs
Blocs de construction de base
Les trois éléments constitutifs d'UML sont -
- Things
- Relationships
- Diagrams
Des choses
Il existe quatre types de choses dans UML, à savoir -
Structural Things- Ce sont les noms des modèles UML représentant les éléments statiques qui peuvent être physiques ou conceptuels. Les éléments structurels sont la classe, l'interface, la collaboration, le cas d'utilisation, la classe active, les composants et les nœuds.
Behavioral Things- Ce sont les verbes des modèles UML représentant le comportement dynamique dans le temps et dans l'espace. Les deux types de choses comportementales sont l'interaction et la machine à états.
Grouping Things- Ils comprennent les parties organisationnelles des modèles UML. Il n'y a qu'un seul type de regroupement, c'est-à-dire un package.
Annotational Things - Ce sont les explications dans les modèles UML représentant les commentaires appliqués pour décrire les éléments.
Des relations
Les relations sont le lien entre les choses. Les quatre types de relations qui peuvent être représentés dans UML sont:
Dependency- Il s'agit d'une relation sémantique entre deux choses telle qu'un changement dans une chose entraîne un changement dans l'autre. La première est la chose indépendante, tandis que la seconde est la chose dépendante.
Association - Il s'agit d'une relation structurelle qui représente un groupe de liens ayant une structure et un comportement communs.
Generalization - Ceci représente une relation de généralisation / spécialisation dans laquelle les sous-classes héritent de la structure et du comportement des super-classes.
Realization - Il s'agit d'une relation sémantique entre deux ou plusieurs classificateurs, de sorte qu'un classificateur établit un contrat que les autres classificateurs s'assurent de respecter.
Diagrammes
Un diagramme est une représentation graphique d'un système. Il comprend un groupe d'éléments généralement sous la forme d'un graphe. UML comprend neuf diagrammes en tout, à savoir -
- Diagramme de classe
- Diagramme d'objets
- Diagramme de cas d'utilisation
- Diagramme de séquençage
- Diagramme de collaboration
- Diagramme de graphique d'état
- Diagramme d'activité
- Diagramme des composants
- Diagramme de déploiement
Règles
UML a un certain nombre de règles afin que les modèles soient sémantiquement auto-cohérents et liés harmonieusement à d'autres modèles du système. UML a des règles sémantiques pour ce qui suit -
- Names
- Scope
- Visibility
- Integrity
- Execution
Mécanismes communs
UML a quatre mécanismes communs -
- Specifications
- Adornments
- Divisions communes
- Mécanismes d'extensibilité
Caractéristiques
En UML, derrière chaque notation graphique, il y a une déclaration textuelle indiquant la syntaxe et la sémantique. Ce sont les spécifications. Les spécifications fournissent un fond de panier sémantique qui contient toutes les parties d'un système et la relation entre les différents chemins.
Ornements
Chaque élément dans UML a une notation graphique unique. En outre, il existe des notations pour représenter les aspects importants d'un élément comme le nom, la portée, la visibilité, etc.
Divisions communes
Les systèmes orientés objet peuvent être divisés de plusieurs manières. Les deux modes de division courants sont:
Division of classes and objects- Une classe est une abstraction d'un groupe d'objets similaires. Un objet est l'instance concrète qui existe réellement dans le système.
Division of Interface and Implementation- Une interface définit les règles d'interaction. La mise en œuvre est la réalisation concrète des règles définies dans l'interface.
Mécanismes d'extensibilité
UML est un langage ouvert. Il est possible d'étendre les capacités d'UML de manière contrôlée pour répondre aux exigences d'un système. Les mécanismes d'extensibilité sont -
Stereotypes - Il étend le vocabulaire de l'UML, grâce auquel de nouveaux blocs de construction peuvent être créés à partir de ceux existants.
Tagged Values - Il étend les propriétés des blocs de construction UML.
Constraints - Il étend la sémantique des blocs de construction UML.
UML définit des notations spécifiques pour chacun des blocs de construction.
Classe
Une classe est représentée par un rectangle comportant trois sections -
- la section supérieure contenant le nom de la classe
- la section du milieu contenant les attributs de classe
- la section inférieure représentant les opérations de la classe
La visibilité des attributs et des opérations peut être représentée de la manière suivante -
Public- Un membre public est visible de n'importe où dans le système. Dans le diagramme de classes, il est préfixé par le symbole «+».
Private- Un membre privé n'est visible que depuis l'intérieur de la classe. Il n'est pas accessible depuis l'extérieur de la classe. Un membre privé est précédé du symbole «-».
Protected- Un membre protégé est visible de l'intérieur de la classe et des sous-classes héritées de cette classe, mais pas de l'extérieur. Il est préfixé par le symbole «#».
Une classe abstraite a le nom de la classe écrit en italique.
Example- Considérons la classe Circle introduite précédemment. Les attributs de Circle sont x-coord, y-coord et radius. Les opérations sont findArea (), findCircumference () et scale (). Supposons que x-coord et y-coord sont des données membres privées, radius est une donnée membre protégée et les fonctions membres sont publiques. La figure suivante donne la représentation schématique de la classe.
Objet
Un objet est représenté comme un rectangle avec deux sections -
La section supérieure contient le nom de l'objet avec le nom de la classe ou du package dont il est une instance. Le nom prend les formes suivantes -
object-name - nom de classe
object-name - nom-classe :: nom-package
class-name - en cas d'objets anonymes
La section inférieure représente les valeurs des attributs. Il prend la forme nom-attribut = valeur.
Parfois, les objets sont représentés à l'aide de rectangles arrondis.
Example- Considérons un objet de la classe Circle nommé c1. Nous supposons que le centre de c1 est à (2, 3) et que le rayon de c1 est 5. La figure suivante représente l'objet.
Composant
Un composant est une partie physique et remplaçable du système qui se conforme et assure la réalisation d'un ensemble d'interfaces. Il représente l'emballage physique d'éléments tels que les classes et les interfaces.
Notation - Dans les diagrammes UML, un composant est représenté par un rectangle avec des tabulations comme le montre la figure ci-dessous.
Interface
L'interface est une collection de méthodes d'une classe ou d'un composant. Il spécifie l'ensemble des services qui peuvent être fournis par la classe ou le composant.
Notation- En général, une interface est dessinée sous forme de cercle avec son nom. Une interface est presque toujours attachée à la classe ou au composant qui la réalise. La figure suivante donne la notation d'une interface.
Paquet
Un package est un groupe d'éléments organisé. Un package peut contenir des éléments structurels tels que des classes, des composants et d'autres packages.
Notation- Graphiquement, un package est représenté par un dossier à onglets. Un package est généralement dessiné avec uniquement son nom. Cependant, il peut avoir des détails supplémentaires sur le contenu du paquet. Voir les figures suivantes.
Relation
Les notations pour les différents types de relations sont les suivantes -
Habituellement, les éléments d'une relation jouent des rôles spécifiques dans la relation. Un nom de rôle signifie le comportement d'un élément participant à un certain contexte.
Example- Les figures suivantes montrent des exemples de différentes relations entre les classes. La première figure montre une association entre deux classes, Département et Employé, dans laquelle un département peut avoir un certain nombre d'employés qui y travaillent. Worker est le nom du rôle. Le «1» à côté de Department et «*» à côté de Employee indiquent que le rapport de cardinalité est de un à plusieurs. La deuxième figure illustre la relation d'agrégation, une université est «l'ensemble» de nombreux départements.
Les diagrammes structurels UML sont classés comme suit: diagramme de classes, diagramme d'objets, diagramme de composants et diagramme de déploiement.
Diagramme de classe
Un diagramme de classes modélise la vue statique d'un système. Il comprend les classes, les interfaces et les collaborations d'un système; et les relations entre eux.
Diagramme de classes d'un système
Prenons un système bancaire simplifié.
Une banque a de nombreuses succursales. Dans chaque zone, une succursale est désignée comme le siège social de la zone qui supervise les autres succursales de cette zone. Chaque succursale peut avoir plusieurs comptes et prêts. Un compte peut être soit un compte d'épargne, soit un compte courant. Un client peut ouvrir à la fois un compte d'épargne et un compte courant. Cependant, un client ne doit pas avoir plus d'un compte d'épargne ou compte courant. Un client peut également obtenir des prêts auprès de la banque.
La figure suivante montre le diagramme de classes correspondant.
Classes dans le système
Banque, succursale, compte, compte d'épargne, compte courant, prêt et client.
Des relations
A Bank “has–a” number of Branches - composition, un à plusieurs
A Branch with role Zonal Head Office supervises other Branches - association unaire, un à plusieurs
A Branch “has–a” number of accounts - agrégation, un à plusieurs
De la classe Compte, deux classes ont hérité, à savoir, Compte d'épargne et Compte courant.
A Customer can have one Current Account - association, un à un
A Customer can have one Savings Account - association, un à un
A Branch “has–a” number of Loans - agrégation, un à plusieurs
A Customer can take many loans - association, un à plusieurs
Diagramme d'objets
Un diagramme d'objets modélise un groupe d'objets et leurs liens à un moment donné. Il montre les instances des choses dans un diagramme de classes. Le diagramme d'objets est la partie statique d'un diagramme d'interaction.
Example - La figure suivante montre un diagramme d'objets d'une partie du diagramme de classes du système bancaire.
Diagramme des composants
Les diagrammes de composants montrent l'organisation et les dépendances au sein d'un groupe de composants.
Les diagrammes de composants comprennent -
- Components
- Interfaces
- Relationships
- Packages et sous-systèmes (facultatif)
Les diagrammes de composants sont utilisés pour -
la construction de systèmes par ingénierie directe et inverse.
modélisation de la gestion de la configuration des fichiers de code source tout en développant un système à l'aide d'un langage de programmation orienté objet.
représentation de schémas dans des bases de données de modélisation.
modélisation des comportements des systèmes dynamiques.
Example
La figure suivante montre un diagramme de composants pour modéliser le code source d'un système développé à l'aide de C ++. Il affiche quatre fichiers de code source, à savoir, myheader.h, otherheader.h, priority.cpp et other.cpp. Deux versions de myheader.h sont affichées, allant de la version récente à son ancêtre. Le fichier priority.cpp a une dépendance de compilation sur other.cpp. Le fichier other.cpp a une dépendance de compilation sur otherheader.h.
Diagramme de déploiement
Un diagramme de déploiement met l'accent sur la configuration des nœuds de traitement d'exécution et de leurs composants qui y vivent. Ils sont généralement constitués de nœuds et de dépendances, ou d'associations entre les nœuds.
Les diagrammes de déploiement sont utilisés pour -
modèles de périphériques dans des systèmes embarqués qui comprennent généralement une collection de matériel informatique intensive.
représentent les topologies des systèmes client / serveur.
modéliser des systèmes entièrement distribués.
Example
La figure suivante montre la topologie d'un système informatique qui suit l'architecture client / serveur. La figure illustre un nœud stéréotypé en tant que serveur qui comprend des processeurs. La figure indique que quatre serveurs ou plus sont déployés sur le système. Les nœuds clients sont connectés au serveur, où chaque nœud représente un périphérique terminal tel qu'un poste de travail, un ordinateur portable, un scanner ou une imprimante. Les nœuds sont représentés à l'aide d'icônes qui représentent clairement l'équivalent dans le monde réel.
Les diagrammes comportementaux UML visualisent, spécifient, construisent et documentent les aspects dynamiques d'un système. Les diagrammes comportementaux sont classés comme suit: diagrammes de cas d'utilisation, diagrammes d'interaction, diagrammes d'état-diagramme et diagrammes d'activités.
Modèle de cas d'utilisation
Cas d'utilisation
Un cas d'utilisation décrit la séquence d'actions qu'un système exécute et produit des résultats visibles. Il montre l'interaction des choses extérieures au système avec le système lui-même. Les cas d'utilisation peuvent être appliqués à l'ensemble du système ainsi qu'à une partie du système.
Acteur
Un acteur représente les rôles que jouent les utilisateurs des cas d'utilisation. Un acteur peut être une personne (par exemple un étudiant, un client), un appareil (par exemple un poste de travail) ou un autre système (par exemple une banque, une institution).
La figure suivante montre les notations d'un acteur nommé Student et d'un cas d'utilisation appelé Generate Performance Report.
Utiliser des diagrammes de cas
Les diagrammes de cas d'utilisation présentent une vue extérieure de la manière dont les éléments d'un système se comportent et comment ils peuvent être utilisés dans le contexte.
Les diagrammes de cas d'utilisation comprennent -
- Cas d'utilisation
- Actors
- Relations comme la dépendance, la généralisation et l'association
Des diagrammes de cas d'utilisation sont utilisés -
Modéliser le contexte d'un système en enfermant toutes les activités d'un système dans un rectangle et en se focalisant sur les acteurs extérieurs au système en interagissant avec lui.
Modéliser les exigences d'un système du point de vue extérieur.
Example
Considérons un système automatisé de maison de commerce. Nous supposons les caractéristiques suivantes du système -
La maison de commerce effectue des transactions avec deux types de clients, les particuliers et les entreprises.
Une fois que le client passe une commande, celle-ci est traitée par le service commercial et le client reçoit la facture.
Le système permet au gestionnaire de gérer les comptes clients et de répondre à toutes les requêtes envoyées par le client.
Diagrammes d'interaction
Les diagrammes d'interaction décrivent les interactions des objets et leurs relations. Ils incluent également les messages passés entre eux. Il existe deux types de diagrammes d'interaction -
- Diagrammes de séquence
- Diagrammes de collaboration
Les diagrammes d'interaction sont utilisés pour la modélisation -
le flux de contrôle par ordre temporel à l'aide de diagrammes de séquence.
le flux de contrôle de l'organisation à l'aide de diagrammes de collaboration.
Diagrammes de séquence
Les diagrammes de séquence sont des diagrammes d'interaction qui illustrent l'ordre des messages en fonction du temps.
Notations- Ces schémas se présentent sous la forme de graphiques bidimensionnels. Les objets qui déclenchent l'interaction sont placés sur l'axe des x. Les messages que ces objets envoient et reçoivent sont placés le long de l'axe y, dans l'ordre de temps croissant de haut en bas.
Example - Un diagramme de séquence pour le système automatisé de la maison de commerce est présenté dans la figure suivante.
Diagrammes de collaboration
Les diagrammes de collaboration sont des diagrammes d'interaction qui illustrent la structure des objets qui envoient et reçoivent des messages.
Notations- Dans ces diagrammes, les objets qui participent à l'interaction sont représentés à l'aide de sommets. Les liens qui connectent les objets sont utilisés pour envoyer et recevoir des messages. Le message est affiché sous la forme d'une flèche étiquetée.
Example - Le diagramme de collaboration pour le système automatisé de la maison de commerce est illustré dans la figure ci-dessous.
Diagrammes d'état-graphique
Un diagramme d'état-graphique montre une machine d'état qui décrit le flux de contrôle d'un objet d'un état à un autre. Une machine à états décrit les séquences d'états qu'un objet subit en raison d'événements et leurs réponses aux événements.
Les diagrammes d'état – graphique comprennent -
- États: simple ou composite
- Transitions entre les états
- Événements provoquant des transitions
- Actions dues aux événements
Les diagrammes d'état sont utilisés pour modéliser des objets de nature réactive.
Example
Dans le système automatisé de la maison de commerce, modélisons l'Ordre en tant qu'objet et traçons sa séquence. La figure suivante montre le diagramme état – diagramme correspondant.
Diagrammes d'activités
Un diagramme d'activités représente le flux d'activités qui sont des opérations non atomiques en cours dans une machine à états. Les activités aboutissent à des actions qui sont des opérations atomiques.
Les diagrammes d'activités comprennent -
- États d'activité et états d'action
- Transitions
- Objects
Les diagrammes d'activités sont utilisés pour la modélisation -
- flux de travail vus par les acteurs, en interaction avec le système.
- détails des opérations ou des calculs à l'aide d'organigrammes.
Example
La figure suivante montre un diagramme d'activité d'une partie du système automatisé de la maison de commerce.
Après la phase d'analyse, le modèle conceptuel est développé en un modèle orienté objet utilisant la conception orientée objet (OOD). Dans OOD, les concepts indépendants de la technologie dans le modèle d'analyse sont mappés sur des classes d'implémentation, les contraintes sont identifiées et les interfaces sont conçues, ce qui donne un modèle pour le domaine de la solution. En un mot, une description détaillée est construite spécifiant comment le système doit être construit sur des technologies concrètes
Les étapes de la conception orientée objet peuvent être identifiées comme suit:
- Définition du contexte du système
- Conception de l'architecture du système
- Identification des objets dans le système
- Construction de modèles de conception
- Spécification des interfaces d'objets
Conception du système
La conception de système orientée objet consiste à définir le contexte d'un système, puis à concevoir l'architecture du système.
Context- Le contexte d'un système a une partie statique et une partie dynamique. Le contexte statique du système est conçu à l'aide d'un simple schéma de principe de l'ensemble du système qui est développé en une hiérarchie de sous-systèmes. Le modèle de sous-système est représenté par des packages UML. Le contexte dynamique décrit comment le système interagit avec son environnement. Il est modélisé en utilisantuse case diagrams.
System Architecture- L'architecture du système est conçue sur la base du contexte du système conformément aux principes de la conception architecturale ainsi que des connaissances du domaine. En règle générale, un système est partitionné en couches et chaque couche est décomposée pour former les sous-systèmes.
Décomposition orientée objet
La décomposition signifie diviser un grand système complexe en une hiérarchie de composants plus petits avec moins de complexités, sur les principes de diviser pour vaincre. Chaque composant majeur du système est appelé un sous-système. La décomposition orientée objet identifie les objets autonomes individuels dans un système et la communication entre ces objets.
Les avantages de la décomposition sont -
Les composants individuels sont moins complexes et donc plus compréhensibles et gérables.
Il permet la division des effectifs ayant des compétences spécialisées.
Il permet aux sous-systèmes d'être remplacés ou modifiés sans affecter les autres sous-systèmes.
Identifier la concurrence
La concurrence permet à plusieurs objets de recevoir des événements en même temps et à plusieurs activités à exécuter simultanément. La concurrence est identifiée et représentée dans le modèle dynamique.
Pour activer la concurrence, chaque élément concurrent se voit attribuer un thread de contrôle distinct. Si la concurrence est au niveau de l'objet, deux objets concurrents se voient attribuer deux threads de contrôle différents. Si deux opérations d'un même objet sont de nature simultanée, cet objet est divisé entre différents threads.
La concurrence est associée aux problèmes d'intégrité des données, de blocage et de famine. Une stratégie claire doit donc être élaborée chaque fois que la concurrence est requise. En outre, la concurrence doit être identifiée au stade de la conception elle-même et ne peut être laissée au stade de la mise en œuvre.
Identification des modèles
Lors de la conception des applications, certaines solutions communément acceptées sont adoptées pour certaines catégories de problèmes. Ce sont les modèles de conception. Un modèle peut être défini comme un ensemble documenté de blocs de construction pouvant être utilisés dans certains types de problèmes de développement d'applications.
Certains modèles de conception couramment utilisés sont -
- Motif de façade
- Modèle de séparation de la vue du modèle
- Modèle d'observateur
- Modèle de modèle de contrôleur de vue
- Publier le modèle d'abonnement
- Modèle proxy
Contrôle des événements
Lors de la conception du système, les événements susceptibles de se produire dans les objets du système doivent être identifiés et traités de manière appropriée.
Un événement est une spécification d'un événement significatif qui a un emplacement dans le temps et l'espace.
Il existe quatre types d'événements qui peuvent être modélisés, à savoir -
Signal Event - Un objet nommé lancé par un objet et capturé par un autre objet.
Call Event - Un événement synchrone représentant l'envoi d'une opération.
Time Event - Un événement représentant le passage du temps.
Change Event - Un événement représentant un changement d'état.
Gestion des conditions aux limites
La phase de conception du système doit aborder l'initialisation et la terminaison du système dans son ensemble ainsi que de chaque sous-système. Les différents aspects documentés sont les suivants -
Le démarrage du système, c'est-à-dire la transition du système de l'état non initialisé à l'état stationnaire.
La fin du système, c'est-à-dire la fermeture de tous les threads en cours d'exécution, le nettoyage des ressources et les messages à envoyer.
La configuration initiale du système et la reconfiguration du système si nécessaire.
Prévoir des pannes ou une interruption indésirable du système.
Les conditions aux limites sont modélisées à l'aide de cas d'utilisation aux limites.
Conception d'objets
Une fois la hiérarchie des sous-systèmes développée, les objets du système sont identifiés et leurs détails sont conçus. Ici, le concepteur détaille la stratégie choisie lors de la conception du système. L'accent passe des concepts du domaine d'application vers les concepts informatiques. Les objets identifiés lors de l'analyse sont gravés pour l'implémentation dans le but de minimiser le temps d'exécution, la consommation de mémoire et le coût global.
La conception d'objets comprend les phases suivantes -
- Identification des objets
- Représentation d'objets, c'est-à-dire construction de modèles de conception
- Classification des opérations
- Conception d'algorithmes
- Conception des relations
- Mise en place du contrôle des interactions externes
- Package des classes et des associations dans des modules
Identification d'objets
La première étape de la conception d'objets est l'identification des objets. Les objets identifiés dans les phases d'analyse orientée objet sont regroupés en classes et affinés afin qu'ils conviennent à une implémentation réelle.
Les fonctions de cette étape sont -
Identifier et affiner les classes dans chaque sous-système ou package
Définition des liens et associations entre les classes
Concevoir les associations hiérarchiques entre les classes, c'est-à-dire la généralisation / spécialisation et les héritages
Conception d'agrégations
Représentation d'objets
Une fois les classes identifiées, elles doivent être représentées à l'aide de techniques de modélisation d'objets. Cette étape consiste essentiellement à construire des diagrammes UML.
Il existe deux types de modèles de conception à produire -
Static Models - Décrire la structure statique d'un système à l'aide de diagrammes de classes et d'objets.
Dynamic Models - Décrire la structure dynamique d'un système et montrer l'interaction entre les classes à l'aide de diagrammes d'interaction et de diagrammes d'états.
Classification des opérations
Dans cette étape, les opérations à effectuer sur les objets sont définies en combinant les trois modèles développés dans la phase OOA, à savoir, modèle objet, modèle dynamique et modèle fonctionnel. Une opération spécifie ce qui doit être fait et non comment cela doit être fait.
Les tâches suivantes sont effectuées concernant les opérations -
Le diagramme de transition d'état de chaque objet du système est développé.
Les opérations sont définies pour les événements reçus par les objets.
Les cas dans lesquels un événement déclenche d'autres événements dans des objets identiques ou différents sont identifiés.
Les sous-opérations au sein des actions sont identifiées.
Les actions principales sont étendues aux diagrammes de flux de données.
Conception d'algorithmes
Les opérations dans les objets sont définies à l'aide d'algorithmes. Un algorithme est une procédure par étapes qui résout le problème posé dans une opération. Les algorithmes se concentrent sur la façon dont cela doit être fait.
Il peut y avoir plus d'un algorithme correspondant à une opération donnée. Une fois les algorithmes alternatifs identifiés, l'algorithme optimal est sélectionné pour le domaine de problème donné. Les métriques pour choisir l'algorithme optimal sont -
Computational Complexity - La complexité détermine l'efficacité d'un algorithme en termes de temps de calcul et de besoins en mémoire.
Flexibility - La flexibilité détermine si l'algorithme choisi peut être mis en œuvre de manière appropriée, sans perte de pertinence dans divers environnements.
Understandability - Cela détermine si l'algorithme choisi est facile à comprendre et à mettre en œuvre.
Conception des relations
La stratégie de mise en œuvre des relations doit être définie lors de la phase de conception de l'objet. Les principales relations abordées comprennent les associations, les agrégations et les héritages.
Le concepteur doit faire ce qui suit concernant les associations -
Identifiez si une association est unidirectionnelle ou bidirectionnelle.
Analysez le chemin des associations et mettez-les à jour si nécessaire.
Implémentez les associations en tant qu'objet distinct, dans le cas de relations plusieurs à plusieurs; ou comme lien vers un autre objet dans le cas de relations un-à-un ou un-à-plusieurs.
En ce qui concerne les héritages, le concepteur doit faire ce qui suit -
Ajustez les classes et leurs associations.
Identifiez les classes abstraites.
Prenez des dispositions pour que les comportements soient partagés au besoin.
Mise en œuvre du contrôle
Le concepteur d'objets peut incorporer des raffinements dans la stratégie du modèle de diagramme d'état. Dans la conception du système, une stratégie de base pour réaliser le modèle dynamique est élaborée. Lors de la conception d'objet, cette stratégie est bien embellie pour une mise en œuvre appropriée.
Les approches de mise en œuvre du modèle dynamique sont:
Represent State as a Location within a Program- Il s'agit de l'approche traditionnelle axée sur les procédures dans laquelle l'emplacement du contrôle définit l'état du programme. Une machine à états finis peut être implémentée en tant que programme. Une transition forme une instruction d'entrée, le chemin de contrôle principal forme la séquence d'instructions, les branches forment les conditions et les chemins vers l'arrière forment les boucles ou itérations.
State Machine Engine- Cette approche représente directement une machine d'état via une classe de moteur de machine d'état. Cette classe exécute la machine à états via un ensemble de transitions et d'actions fournies par l'application.
Control as Concurrent Tasks- Dans cette approche, un objet est implémenté en tant que tâche dans le langage de programmation ou le système d'exploitation. Ici, un événement est implémenté comme un appel inter-tâches. Il préserve la concurrence intrinsèque des objets réels.
Classes d'emballage
Dans tout grand projet, le partitionnement méticuleux d'une implémentation en modules ou packages est important. Lors de la conception des objets, les classes et les objets sont regroupés dans des packages pour permettre à plusieurs groupes de travailler en coopération sur un projet.
Les différents aspects de l'emballage sont -
Hiding Internal Information from Outside View - Il permet à une classe d'être considérée comme une «boîte noire» et permet de modifier l'implémentation de classe sans que les clients de la classe modifient le code.
Coherence of Elements - Un élément, tel qu'une classe, une opération ou un module, est cohérent s'il est organisé sur un plan cohérent et que toutes ses parties sont intrinsèquement liées de manière à servir un objectif commun.
Construction of Physical Modules - Les instructions suivantes aident lors de la construction de modules physiques -
Les classes d'un module doivent représenter des éléments ou des composants similaires dans le même objet composite.
Les classes étroitement connectées doivent être dans le même module.
Les classes non connectées ou faiblement connectées doivent être placées dans des modules séparés.
Les modules doivent avoir une bonne cohésion, c'est-à-dire une coopération élevée entre ses composants.
Un module doit avoir un faible couplage avec d'autres modules, c'est-à-dire que l'interaction ou l'interdépendance entre les modules doit être minimale.
Optimisation de la conception
Le modèle d'analyse capture les informations logiques sur le système, tandis que le modèle de conception ajoute des détails pour permettre un accès efficace aux informations. Avant qu'une conception ne soit mise en œuvre, elle doit être optimisée afin de rendre la mise en œuvre plus efficace. Le but de l'optimisation est de minimiser le coût en termes de temps, d'espace et d'autres paramètres.
Cependant, l'optimisation de la conception ne doit pas être excessive, car la facilité de mise en œuvre, la maintenabilité et l'extensibilité sont également des préoccupations importantes. On voit souvent qu'un design parfaitement optimisé est plus efficace mais moins lisible et réutilisable. Le concepteur doit donc trouver un équilibre entre les deux.
Les différentes choses qui peuvent être faites pour l'optimisation de la conception sont:
- Ajouter des associations redondantes
- Omettre les associations non utilisables
- Optimisation des algorithmes
- Enregistrer les attributs dérivés pour éviter le recalcul d'expressions complexes
Ajout d'associations redondantes
Lors de l'optimisation de la conception, il est vérifié si la dérivation de nouvelles associations peut réduire les coûts d'accès. Bien que ces associations redondantes n'apportent aucune information, elles peuvent augmenter l'efficacité du modèle global.
Omission des associations non utilisables
La présence d'un trop grand nombre d'associations peut rendre un système indéchiffrable et donc réduire l'efficacité globale du système. Ainsi, lors de l'optimisation, toutes les associations non utilisables sont supprimées.
Optimisation des algorithmes
Dans les systèmes orientés objet, l'optimisation de la structure des données et des algorithmes se fait de manière collaborative. Une fois la conception de classe en place, les opérations et les algorithmes doivent être optimisés.
L'optimisation des algorithmes est obtenue par -
- Réorganisation de l'ordre des tâches de calcul
- Inversion de l'ordre d'exécution des boucles par rapport à celui défini dans le modèle fonctionnel
- Suppression des chemins morts dans l'algorithme
Enregistrement et stockage des attributs dérivés
Les attributs dérivés sont les attributs dont les valeurs sont calculées en fonction d'autres attributs (attributs de base). Le recalcul des valeurs des attributs dérivés chaque fois qu'ils sont nécessaires est une procédure qui prend du temps. Pour éviter cela, les valeurs peuvent être calculées et stockées dans leurs formes calculées.
Cependant, cela peut entraîner des anomalies de mise à jour, c'est-à-dire un changement des valeurs des attributs de base sans changement correspondant des valeurs des attributs dérivés. Pour éviter cela, les étapes suivantes sont suivies -
À chaque mise à jour de la valeur d'attribut de base, l'attribut dérivé est également recalculé.
Tous les attributs dérivés sont recalculés et mis à jour périodiquement dans un groupe plutôt qu'après chaque mise à jour.
Documentation de conception
La documentation est une partie essentielle de tout processus de développement logiciel qui enregistre la procédure de création du logiciel. Les décisions de conception doivent être documentées pour tout système logiciel non trivial pour transmettre la conception à d'autres.
Domaines d'utilisation
Bien qu'il s'agisse d'un produit secondaire, une bonne documentation est indispensable, en particulier dans les domaines suivants -
- Lors de la conception de logiciels développés par un certain nombre de développeurs
- Dans les stratégies de développement logiciel itératives
- Lors du développement de versions ultérieures d'un projet logiciel
- Pour évaluer un logiciel
- Pour trouver les conditions et les zones de test
- Pour la maintenance du logiciel.
Contenu
Une documentation utile devrait essentiellement inclure le contenu suivant -
High–level system architecture - Diagrammes de processus et diagrammes de modules
Key abstractions and mechanisms - Diagrammes de classes et diagrammes d'objets.
Scenarios that illustrate the behavior of the main aspects - Diagrammes comportementaux
traits
Les caractéristiques d'une bonne documentation sont -
Concis et en même temps, sans ambiguïté, cohérent et complet
Traçable selon les spécifications des exigences du système
Well-structured
Diagrammatique au lieu de descriptif
La mise en œuvre d'une conception orientée objet implique généralement l'utilisation d'un langage de programmation orienté objet (OOPL) standard ou le mappage de conceptions d'objets sur des bases de données. Dans la plupart des cas, cela implique les deux.
Implémentation à l'aide de langages de programmation
Habituellement, la tâche de transformer une conception d'objet en code est un processus simple. Tout langage de programmation orienté objet comme C ++, Java, Smalltalk, C # et Python, inclut des dispositions pour représenter des classes. Dans ce chapitre, nous illustrons le concept en utilisant C ++.
La figure suivante montre la représentation de la classe Circle à l'aide de C ++.
Association de mise en œuvre
La plupart des langages de programmation ne fournissent pas de constructions pour implémenter directement des associations. La tâche de mise en place des associations nécessite donc une réflexion approfondie.
Les associations peuvent être unidirectionnelles ou bidirectionnelles. En outre, chaque association peut être un à un, un à plusieurs ou plusieurs à plusieurs.
Associations unidirectionnelles
Pour la mise en œuvre d'associations unidirectionnelles, il faut prendre soin de conserver l'unidirectionnalité. Les implémentations pour différentes multiplicité sont les suivantes -
Optional Associations- Ici, un lien peut ou non exister entre les objets participants. Par exemple, dans l'association entre le client et le compte courant dans la figure ci-dessous, un client peut ou non avoir un compte courant.
Pour l'implémentation, un objet de compte courant est inclus en tant qu'attribut dans Customer qui peut être NULL. Implémentation en C ++ -
class Customer {
private:
// attributes
Current_Account c; //an object of Current_Account as attribute
public:
Customer() {
c = NULL;
} // assign c as NULL
Current_Account getCurrAc() {
return c;
}
void setCurrAc( Current_Account myacc) {
c = myacc;
}
void removeAcc() {
c = NULL;
}
};
One–to–one Associations- Ici, une instance d'une classe est liée à exactement une instance de la classe associée. Par exemple, le service et le gestionnaire ont une association un à un, comme illustré dans la figure ci-dessous.
Ceci est implémenté en incluant dans Department, un objet de Manager qui ne doit pas être NULL. Implémentation en C ++ -
class Department {
private:
// attributes
Manager mgr; //an object of Manager as attribute
public:
Department (/*parameters*/, Manager m) { //m is not NULL
// assign parameters to variables
mgr = m;
}
Manager getMgr() {
return mgr;
}
};
One–to–many Associations- Ici, une instance d'une classe est liée à plusieurs instances de la classe associée. Par exemple, considérez l'association entre l'employé et la personne à charge dans la figure suivante.
Ceci est implémenté en incluant une liste de personnes à charge dans la classe Employee. Implémentation à l'aide du conteneur de liste C ++ STL -
class Employee {
private:
char * deptName;
list <Dependent> dep; //a list of Dependents as attribute
public:
void addDependent ( Dependent d) {
dep.push_back(d);
} // adds an employee to the department
void removeDeoendent( Dependent d) {
int index = find ( d, dep );
// find() function returns the index of d in list dep
dep.erase(index);
}
};
Associations bidirectionnelles
Pour mettre en œuvre une association bidirectionnelle, les liens dans les deux sens doivent être maintenus.
Optional or one–to–one Associations - Considérez la relation entre le projet et le gestionnaire de projet ayant une association bidirectionnelle un à un comme le montre la figure ci-dessous.
Implémentation en C ++ -
Class Project {
private:
// attributes
Project_Manager pmgr;
public:
void setManager ( Project_Manager pm);
Project_Manager changeManager();
};
class Project_Manager {
private:
// attributes
Project pj;
public:
void setProject(Project p);
Project removeProject();
};
One–to–many Associations - Considérez la relation entre le ministère et l'employé ayant une association un à plusieurs, comme le montre la figure ci-dessous.
Implémentation à l'aide du conteneur de liste C ++ STL
class Department {
private:
char * deptName;
list <Employee> emp; //a list of Employees as attribute
public:
void addEmployee ( Employee e) {
emp.push_back(e);
} // adds an employee to the department
void removeEmployee( Employee e) {
int index = find ( e, emp );
// find function returns the index of e in list emp
emp.erase(index);
}
};
class Employee {
private:
//attributes
Department d;
public:
void addDept();
void removeDept();
};
Implémentation d'associations en tant que classes
Si une association a des attributs associés, elle doit être implémentée en utilisant une classe distincte. Par exemple, considérez l'association un à un entre l'employé et le projet, comme illustré dans la figure ci-dessous.
Implémentation de WorksOn en C ++
class WorksOn {
private:
Employee e;
Project p;
Hours h;
char * date;
public:
// class methods
};
Implémentation de contraintes
Les contraintes dans les classes restreignent la plage et le type de valeurs que les attributs peuvent prendre. Afin d'implémenter des contraintes, une valeur par défaut valide est attribuée à l'attribut lorsqu'un objet est instancié à partir de la classe. Chaque fois que la valeur est modifiée lors de l'exécution, il est vérifié si la valeur est valide ou non. Une valeur non valide peut être gérée par une routine de gestion des exceptions ou par d'autres méthodes.
Example
Considérez une classe Employee où l'âge est un attribut qui peut avoir des valeurs comprises entre 18 et 60. Le code C ++ suivant l'incorpore -
class Employee {
private: char * name;
int age;
// other attributes
public:
Employee() { // default constructor
strcpy(name, "");
age = 18; // default value
}
class AgeError {}; // Exception class
void changeAge( int a) { // method that changes age
if ( a < 18 || a > 60 ) // check for invalid condition
throw AgeError(); // throw exception
age = a;
}
};
Implémentation des graphiques d'état
Il existe deux stratégies de mise en œuvre alternatives pour implémenter les états dans les diagrammes d'état.
Énumérations dans la classe
Dans cette approche, les états sont représentés par différentes valeurs d'un membre de données (ou d'un ensemble de membres de données). Les valeurs sont explicitement définies par une énumération dans la classe. Les transitions sont représentées par des fonctions membres qui modifient la valeur du membre de données concerné.
Disposition des classes dans une hiérarchie de généralisation
Dans cette approche, les états sont disposés dans une hiérarchie de généralisation de manière à pouvoir être référencés par une variable de pointeur commune. La figure suivante montre une transformation d'un diagramme d'état en une hiérarchie de généralisation.
Mappage d'objets au système de base de données
Persistance des objets
Un aspect important du développement de systèmes orientés objet est la persistance des données. Grâce à la persistance, les objets ont une durée de vie plus longue que le programme qui les a créés. Les données persistantes sont enregistrées sur un support de stockage secondaire à partir duquel elles peuvent être rechargées si nécessaire.
Aperçu du SGBDR
Une base de données est une collection ordonnée de données associées.
Un système de gestion de base de données (SGBD) est un ensemble de logiciels qui facilite les processus de définition, de création, de stockage, de manipulation, de récupération, de partage et de suppression de données dans des bases de données.
Dans les systèmes de gestion de base de données relationnelle (SGBDR), les données sont stockées sous forme de relations ou de tables, où chaque colonne ou champ représente un attribut et chaque ligne ou tuple représente un enregistrement d'une instance.
Chaque ligne est identifiée de manière unique par un ensemble choisi d'attributs minimaux appelés primary key.
UNE foreign key est un attribut qui est la clé primaire d'une table associée.
Représenter les classes sous forme de tableaux dans le SGBDR
Pour mapper une classe à une table de base de données, chaque attribut est représenté comme un champ dans la table. Soit un ou plusieurs attributs existants sont affectés en tant que clé primaire, soit un champ ID distinct est ajouté en tant que clé primaire. La classe peut être partitionnée horizontalement ou verticalement selon les besoins.
Par exemple, la classe Circle peut être convertie en table comme indiqué dans la figure ci-dessous.
Schema for Circle Table: CIRCLE(CID, X_COORD, Y_COORD, RADIUS, COLOR)
Creating a Table Circle using SQL command:
CREATE TABLE CIRCLE (
CID VARCHAR2(4) PRIMARY KEY,
X_COORD INTEGER NOT NULL,
Y_COORD INTEGER NOT NULL,
Z_COORD INTEGER NOT NULL,
COLOR
);
Mappage d'associations sur des tables de base de données
Associations un-à-un
Pour implémenter des associations 1: 1, la clé primaire d'une table est affectée comme clé étrangère de l'autre table. Par exemple, considérons l'association entre le service et le gestionnaire -
Commandes SQL pour créer les tables
CREATE TABLE DEPARTMENT (
DEPT_ID INTEGER PRIMARY KEY,
DNAME VARCHAR2(30) NOT NULL,
LOCATION VARCHAR2(20),
EMPID INTEGER REFERENCES MANAGER
);
CREATE TABLE MANAGER (
EMPID INTEGER PRIMARY KEY,
ENAME VARCHAR2(50) NOT NULL,
ADDRESS VARCHAR2(70),
);
Associations un à plusieurs
Pour implémenter des associations 1: N, la clé primaire de la table du côté 1 de l'association est affectée comme clé étrangère de la table du côté N de l'association. Par exemple, considérons l'association entre le ministère et l'employé -
Commandes SQL pour créer les tables
CREATE TABLE DEPARTMENT (
DEPT_ID INTEGER PRIMARY KEY,
DNAME VARCHAR2(30) NOT NULL,
LOCATION VARCHAR2(20),
);
CREATE TABLE EMPLOYEE (
EMPID INTEGER PRIMARY KEY,
ENAME VARCHAR2(50) NOT NULL,
ADDRESS VARCHAR2(70),
D_ID INTEGER REFERENCES DEPARTMENT
);
Associations plusieurs à plusieurs
Pour implémenter les associations M: N, une nouvelle relation est créée qui représente l'association. Par exemple, considérons l'association suivante entre l'employé et le projet -
Schema for Works_On Table - WORKS_ON (EMPID, PID, HOURS, START_DATE)
SQL command to create Works_On association - CRÉER UNE TABLE WORKS_ON
(
EMPID INTEGER,
PID INTEGER,
HOURS INTEGER,
START_DATE DATE,
PRIMARY KEY (EMPID, PID),
FOREIGN KEY (EMPID) REFERENCES EMPLOYEE,
FOREIGN KEY (PID) REFERENCES PROJECT
);
Mappage de l'héritage sur les tables
Pour mapper l'héritage, la clé primaire de la ou des tables de base est affectée comme clé primaire ainsi que la clé étrangère dans la ou les tables dérivées.
Example
Une fois qu'un code de programme est écrit, il doit être testé pour détecter et ensuite gérer toutes les erreurs qu'il contient. Un certain nombre de schémas sont utilisés à des fins de test.
Un autre aspect important est l'adéquation de l'objectif d'un programme qui vérifie si le programme sert l'objectif pour lequel il vise. La forme physique définit la qualité du logiciel.
Test des systèmes orientés objet
Le test est une activité continue pendant le développement logiciel. Dans les systèmes orientés objet, les tests englobent trois niveaux, à savoir, les tests unitaires, les tests de sous-systèmes et les tests de système.
Test unitaire
Dans les tests unitaires, les classes individuelles sont testées. On voit si les attributs de classe sont implémentés conformément à la conception et si les méthodes et les interfaces sont sans erreur. Les tests unitaires sont sous la responsabilité de l'ingénieur d'application qui met en œuvre la structure.
Test de sous-système
Cela implique de tester un module ou un sous-système particulier et est de la responsabilité du responsable du sous-système. Il s'agit de tester les associations au sein du sous-système ainsi que l'interaction du sous-système avec l'extérieur. Les tests de sous-système peuvent être utilisés comme tests de régression pour chaque version nouvellement publiée du sous-système.
Test du système
Le test du système implique le test du système dans son ensemble et relève de la responsabilité de l'équipe d'assurance qualité. L'équipe utilise souvent des tests système comme tests de régression lors de l'assemblage de nouvelles versions.
Techniques de test orientées objet
Test de la boîte grise
Les différents types de cas de test qui peuvent être conçus pour tester des programmes orientés objet sont appelés cas de test de boîte grise. Certains des types importants de tests de boîte grise sont:
State model based testing - Cela englobe la couverture d'état, la couverture de transition d'état et la couverture de chemin de transition d'état.
Use case based testing - Chaque scénario de chaque cas d'utilisation est testé.
Class diagram based testing - Chaque classe, classe dérivée, associations et agrégations sont testées.
Sequence diagram based testing - Les méthodes des messages des diagrammes de séquence sont testées.
Techniques de test de sous-système
Les deux principales approches des tests de sous-systèmes sont:
Thread based testing - Toutes les classes nécessaires pour réaliser un cas d'utilisation unique dans un sous-système sont intégrées et testées.
Use based testing- Les interfaces et services des modules à chaque niveau de hiérarchie sont testés. Les tests commencent des classes individuelles aux petits modules comprenant des classes, progressivement vers des modules plus grands, et enfin tous les principaux sous-systèmes.
Catégories de tests système
Alpha testing - Ceci est effectué par l'équipe de test au sein de l'organisation qui développe le logiciel.
Beta testing - Ceci est effectué par un groupe restreint de clients coopérants.
Acceptance testing - Ceci est effectué par le client avant d'accepter les livrables.
Assurance qualité des logiciels
Qualité du logiciel
Schulmeyer et McManus ont défini la qualité du logiciel comme «l'aptitude à l'emploi de l'ensemble du produit logiciel». Un logiciel de bonne qualité fait exactement ce qu'il est censé faire et est interprété en termes de satisfaction de la spécification d'exigence établie par l'utilisateur.
Assurance qualité
L'assurance qualité logicielle est une méthodologie qui détermine dans quelle mesure un produit logiciel est apte à être utilisé. Les activités incluses pour déterminer la qualité du logiciel sont:
- Auditing
- Développement de normes et de lignes directrices
- Production de rapports
- Examen du système qualité
Facteurs de qualité
Correctness - L'exactitude détermine si les exigences logicielles sont satisfaites de manière appropriée.
Usability - La convivialité détermine si le logiciel peut être utilisé par différentes catégories d'utilisateurs (débutants, non techniques et experts).
Portability - La portabilité détermine si le logiciel peut fonctionner sur différentes plates-formes avec différents périphériques matériels.
Maintainability - La maintenabilité détermine la facilité avec laquelle les erreurs peuvent être corrigées et les modules peuvent être mis à jour.
Reusability - La réutilisation détermine si les modules et les classes peuvent être réutilisés pour développer d'autres produits logiciels.
Métriques orientées objet
Les métriques peuvent être globalement classées en trois catégories: les métriques de projet, les métriques de produit et les métriques de processus.
Mesures du projet
Les métriques de projet permettent à un chef de projet logiciel d'évaluer l'état et la performance d'un projet en cours. Les métriques suivantes sont appropriées pour les projets logiciels orientés objet -
- Nombre de scripts de scénario
- Nombre de classes clés
- Nombre de classes de support
- Nombre de sous-systèmes
Mesures du produit
Les métriques de produit mesurent les caractéristiques du produit logiciel qui a été développé. Les métriques de produit adaptées aux systèmes orientés objet sont:
Methods per Class- Il détermine la complexité d'une classe. Si toutes les méthodes d'une classe sont supposées être également complexes, alors une classe avec plus de méthodes est plus complexe et donc plus sensible aux erreurs.
Inheritance Structure- Les systèmes avec plusieurs petits réseaux d'héritage sont plus bien structurés que les systèmes avec un seul grand réseau d'héritage. En règle générale, un arbre d'héritage ne doit pas avoir plus de 7 (± 2) niveaux et l'arbre doit être équilibré.
Coupling and Cohesion - Les modules ayant un faible couplage et une cohésion élevée sont considérés comme étant mieux conçus, car ils permettent une plus grande réutilisabilité et maintenabilité.
Response for a Class - Il mesure l'efficacité des méthodes appelées par les instances de la classe.
Métriques de processus
Les métriques de processus aident à mesurer les performances d'un processus. Ils sont collectés sur tous les projets sur de longues périodes. Ils sont utilisés comme indicateurs pour les améliorations à long terme des processus logiciels. Certaines métriques de processus sont -
- Nombre de KLOC (Kilo Lines of Code)
- Efficacité d'élimination des défauts
- Nombre moyen de pannes détectées lors des tests
- Nombre de vices cachés par KLOC