Génie logiciel - Guide rapide
Voyons d'abord ce que signifie le génie logiciel. Le terme est composé de deux mots, logiciel et ingénierie.
Software est plus qu'un simple code de programme. Un programme est un code exécutable, qui sert à des fins de calcul. Le logiciel est considéré comme une collection de code de programmation exécutable, de bibliothèques associées et de documentations. Le logiciel, lorsqu'il est conçu pour une exigence spécifique, est appelésoftware product.
Engineering d'autre part, il s'agit de développer des produits, en utilisant des principes et des méthodes scientifiques bien définis.
Software engineeringest une branche d'ingénierie associée au développement de produits logiciels en utilisant des principes, méthodes et procédures scientifiques bien définis. Le résultat de l'ingénierie logicielle est un produit logiciel efficace et fiable.
Définitions
IEEE définit l'ingénierie logicielle comme:
(1) L'application d'une approche systématique, disciplinée et quantifiable du développement, de l'exploitation et de la maintenance des logiciels; c'est-à-dire l'application de l'ingénierie aux logiciels.
(2) L'étude des approches comme dans la déclaration ci-dessus.
Fritz Bauer, un informaticien allemand, définit le génie logiciel comme:
L'ingénierie logicielle est l'établissement et l'utilisation de principes d'ingénierie solides afin d'obtenir des logiciels économiquement fiables et fonctionnant efficacement sur des machines réelles.
Evolution du logiciel
Le processus de développement d'un produit logiciel utilisant des principes et des méthodes de génie logiciel est appelé software evolution. Cela comprend le développement initial du logiciel, sa maintenance et ses mises à jour, jusqu'à ce que le produit logiciel souhaité soit développé, qui réponde aux exigences attendues.
L'évolution commence par le processus de collecte des exigences. Après quoi les développeurs créent un prototype du logiciel prévu et le montrent aux utilisateurs pour obtenir leurs commentaires au début du développement du produit logiciel. Les utilisateurs suggèrent des changements, sur lesquels plusieurs mises à jour et maintenance consécutives continuent également de changer. Ce processus change pour le logiciel d'origine, jusqu'à ce que le logiciel souhaité soit accompli.
Même une fois que l'utilisateur a souhaité le logiciel en main, les progrès de la technologie et les exigences changeantes obligent le logiciel à changer en conséquence. Il n'est pas possible de recréer un logiciel à partir de zéro et de répondre individuellement aux exigences. La seule solution réalisable et économique consiste à mettre à jour le logiciel existant afin qu'il corresponde aux dernières exigences.
Lois d'évolution logicielle
Lehman a donné des lois pour l'évolution des logiciels. Il a divisé le logiciel en trois catégories différentes:
- S-type (static-type) - Il s'agit d'un logiciel qui fonctionne strictement selon des spécifications et des solutions définies . La solution et la méthode pour y parvenir, toutes deux sont immédiatement comprises avant le codage. Le logiciel de type s est le moins sujet aux changements, c'est donc le plus simple de tous. Par exemple, programme de calculatrice pour le calcul mathématique.
- P-type (practical-type) - Il s'agit d'un logiciel avec une collection de procédures. Ceci est défini par exactement ce que les procédures peuvent faire. Dans ce logiciel, les spécifications peuvent être décrites mais la solution n'est pas évidente instantanément. Par exemple, un logiciel de jeu.
- E-type (embedded-type) - Ce logiciel fonctionne étroitement comme l'exigence d'un environnement réel . Ce logiciel a un haut degré d'évolution car il y a divers changements dans les lois, les taxes, etc. dans les situations du monde réel. Par exemple, un logiciel de trading en ligne.
Évolution du logiciel E-Type
Lehman a donné huit lois pour l'évolution du logiciel E-Type -
- Continuing change - Un système logiciel de type E doit continuer à s'adapter aux changements du monde réel, sinon il devient progressivement moins utile.
- Increasing complexity - Au fur et à mesure qu'un système logiciel de type E évolue, sa complexité a tendance à augmenter à moins que des travaux ne soient effectués pour le maintenir ou le réduire.
- Conservation of familiarity - La familiarité avec le logiciel ou les connaissances sur la façon dont il a été développé, pourquoi il a été développé de cette manière particulière, etc. doivent être conservés à tout prix pour mettre en œuvre les changements dans le système.
- Continuing growth- Pour qu'un système de type E destiné à résoudre un problème commercial, sa taille de mise en œuvre des changements augmente en fonction des changements de style de vie de l'entreprise.
- Reducing quality - Un système logiciel de type E décline en qualité à moins d'être rigoureusement entretenu et adapté à un environnement opérationnel changeant.
- Feedback systems- Les systèmes logiciels de type E constituent des systèmes de rétroaction multi-boucles et multi-niveaux et doivent être traités comme tels pour être modifiés ou améliorés avec succès.
- Self-regulation - Les processus d'évolution du système de type E s'autorégulent avec la distribution des mesures de produit et de processus proche de la normale.
- Organizational stability - Le taux d'activité global effectif moyen dans un système de type E en évolution est invariant sur la durée de vie du produit.
Paradigmes logiciels
Les paradigmes logiciels font référence aux méthodes et aux étapes qui sont prises lors de la conception du logiciel. De nombreuses méthodes sont proposées et sont en cours de travail aujourd'hui, mais nous devons voir où en génie logiciel ces paradigmes se situent. Ceux-ci peuvent être combinés en différentes catégories, bien que chacune d'elles soit contenue l'une dans l'autre:
Le paradigme de programmation est un sous-ensemble du paradigme de conception de logiciel qui est en outre un sous-ensemble du paradigme de développement de logiciel.
Paradigme de développement logiciel
Ce paradigme est connu sous le nom de paradigmes d'ingénierie logicielle où tous les concepts d'ingénierie relatifs au développement de logiciels sont appliqués. Il comprend diverses recherches et la collecte d'exigences qui aident le produit logiciel à se construire. Cela consiste en -
- Collecte des exigences
- Conception de logiciels
- Programming
Paradigme de conception de logiciel
Ce paradigme fait partie du développement logiciel et comprend -
- Design
- Maintenance
- Programming
Paradigme de programmation
Ce paradigme est étroitement lié à l'aspect programmation du développement logiciel. Ceci comprend -
- Coding
- Testing
- Integration
Besoin de génie logiciel
Le besoin de génie logiciel survient en raison du taux plus élevé de changement des exigences des utilisateurs et de l'environnement sur lequel le logiciel fonctionne.
- Large software - De même, il est plus facile de construire un mur que de construire une maison ou un bâtiment, car la taille du logiciel devient grande, l'ingénierie doit faire un pas pour lui donner un processus scientifique.
- Scalability- Si le processus logiciel n'était pas basé sur des concepts scientifiques et techniques, il serait plus facile de recréer un nouveau logiciel que de mettre à l'échelle un logiciel existant.
- Cost- Comme l'industrie du matériel a montré ses compétences et son énorme fabrication, le prix du matériel informatique et électronique a baissé. Mais le coût du logiciel reste élevé si le processus approprié n'est pas adapté.
- Dynamic Nature- La nature toujours croissante et adaptative des logiciels dépend énormément de l'environnement dans lequel l'utilisateur travaille. Si la nature du logiciel change constamment, de nouvelles améliorations doivent être apportées au logiciel existant. C'est là que le génie logiciel joue un bon rôle.
- Quality Management- Un meilleur processus de développement logiciel fournit un produit logiciel meilleur et de qualité.
Caractéristiques d'un bon logiciel
Un produit logiciel peut être jugé en fonction de ce qu'il offre et de sa capacité à être utilisé. Ce logiciel doit satisfaire pour les motifs suivants:
- Operational
- Transitional
- Maintenance
On s'attend à ce qu'un logiciel bien conçu et conçu présente les caractéristiques suivantes:
Opérationnel
Cela nous indique à quel point le logiciel fonctionne bien dans les opérations. Il peut être mesuré sur:
- Budget
- Usability
- Efficiency
- Correctness
- Functionality
- Dependability
- Security
- Safety
De transition
Cet aspect est important lorsque le logiciel est déplacé d'une plateforme à une autre:
- Portability
- Interoperability
- Reusability
- Adaptability
Entretien
Cet aspect explique dans quelle mesure un logiciel a les capacités de se maintenir dans un environnement en constante évolution:
- Modularity
- Maintainability
- Flexibility
- Scalability
En bref, le génie logiciel est une branche de l'informatique, qui utilise des concepts d'ingénierie bien définis nécessaires pour produire des produits logiciels efficaces, durables, évolutifs, respectueux du budget et dans les délais.
Le cycle de vie du développement logiciel, en abrégé SDLC, est une séquence bien définie et structurée d'étapes du génie logiciel pour développer le produit logiciel prévu.
Activités SDLC
SDLC fournit une série d'étapes à suivre pour concevoir et développer efficacement un produit logiciel. Le cadre SDLC comprend les étapes suivantes:
la communication
C'est la première étape où l'utilisateur lance la demande d'un produit logiciel souhaité. Il contacte le fournisseur de services et essaie de négocier les conditions. Il soumet sa demande par écrit à l'organisme prestataire de services.
Rassemblement des exigences
Cette étape, l'équipe de développement logiciel travaille pour poursuivre le projet. L'équipe discute avec divers intervenants du domaine problématique et essaie de faire ressortir le plus d'informations possible sur leurs besoins. Les exigences sont envisagées et séparées en exigences utilisateur, exigences système et exigences fonctionnelles. Les exigences sont collectées en utilisant un certain nombre de pratiques telles que données -
- étudier le système et les logiciels existants ou obsolètes,
- mener des interviews d'utilisateurs et de développeurs,
- se référant à la base de données ou
- recueillir les réponses des questionnaires.
Étude de faisabilité
Après la collecte des exigences, l'équipe propose un plan approximatif du processus logiciel. À cette étape, l'équipe analyse si un logiciel peut être conçu pour répondre à toutes les exigences de l'utilisateur et s'il existe une possibilité que le logiciel ne soit plus utile. Il est découvert si le projet est financièrement, pratiquement et technologiquement réalisable pour l'organisation. Il existe de nombreux algorithmes disponibles, qui aident les développeurs à conclure la faisabilité d'un projet logiciel.
L'analyse du système
À cette étape, les développeurs décident d'une feuille de route de leur plan et essaient de proposer le meilleur modèle de logiciel adapté au projet. L'analyse du système comprend la compréhension des limites du produit logiciel, l'apprentissage des problèmes liés au système ou des changements à effectuer dans les systèmes existants à l'avance, l'identification et le traitement de l'impact du projet sur l'organisation et le personnel, etc. L'équipe de projet analyse la portée du projet et planifie le calendrier et ressources en conséquence.
Conception de logiciels
L'étape suivante consiste à apporter une connaissance approfondie des exigences et des analyses sur le bureau et à concevoir le produit logiciel. Les contributions des utilisateurs et les informations recueillies lors de la phase de collecte des exigences sont les entrées de cette étape. Le résultat de cette étape se présente sous la forme de deux modèles; conception logique et conception physique. Les ingénieurs produisent des métadonnées et des dictionnaires de données, des diagrammes logiques, des diagrammes de flux de données et, dans certains cas, des pseudo codes.
Codage
Cette étape est également appelée phase de programmation. La mise en œuvre de la conception logicielle commence par l'écriture de code de programme dans le langage de programmation approprié et le développement efficace de programmes exécutables sans erreur.
Essai
Une estimation indique que 50% de l'ensemble du processus de développement logiciel devrait être testé. Des erreurs peuvent ruiner le logiciel du niveau critique à sa propre suppression. Les tests logiciels sont effectués pendant le codage par les développeurs et des tests approfondis sont effectués par des experts en test à différents niveaux de code tels que les tests de modules, les tests de programmes, les tests de produits, les tests en interne et les tests du produit du côté de l'utilisateur. La découverte précoce des erreurs et de leur remède est la clé d'un logiciel fiable.
L'intégration
Il se peut que le logiciel doive être intégré aux bibliothèques, bases de données et autres programmes. Cette étape du SDLC est impliquée dans l'intégration du logiciel avec les entités du monde extérieur.
la mise en oeuvre
Cela signifie installer le logiciel sur les machines des utilisateurs. Parfois, le logiciel a besoin de configurations post-installation du côté de l'utilisateur. Le logiciel est testé pour la portabilité et l'adaptabilité et les problèmes liés à l'intégration sont résolus pendant la mise en œuvre.
Opération et maintenance
Cette phase confirme le fonctionnement du logiciel en termes de plus d'efficacité et moins d'erreurs. Si nécessaire, les utilisateurs sont formés ou aidés avec la documentation sur la façon d'utiliser le logiciel et comment maintenir le logiciel opérationnel. Le logiciel est maintenu en temps opportun en mettant à jour le code en fonction des changements intervenus dans l'environnement ou la technologie de l'utilisateur final. Cette phase peut être confrontée à des défis liés à des bogues cachés et à des problèmes non identifiés du monde réel.
Disposition
Au fil du temps, le logiciel peut décliner sur le plan des performances. Il peut devenir complètement obsolète ou nécessiter une mise à niveau intense. D'où un besoin pressant d'éliminer une grande partie du système. Cette phase comprend l'archivage des données et des composants logiciels requis, la fermeture du système, la planification des activités d'élimination et l'arrêt du système à l'heure de fin de système appropriée.
Paradigme de développement logiciel
Le paradigme du développement logiciel aide le développeur à sélectionner une stratégie pour développer le logiciel. Un paradigme de développement logiciel a son propre ensemble d'outils, de méthodes et de procédures, qui sont exprimés clairement et définissent le cycle de vie du développement logiciel. Quelques paradigmes de développement logiciel ou modèles de processus sont définis comme suit:
Modèle de cascade
Le modèle en cascade est le modèle le plus simple de paradigme de développement logiciel. Il dit que toutes les phases du SDLC fonctionneront les unes après les autres de manière linéaire. Autrement dit, lorsque la première phase est terminée, seule la deuxième phase commencera et ainsi de suite.
Ce modèle suppose que tout est exécuté et s'est déroulé parfaitement comme prévu à l'étape précédente et qu'il n'est pas nécessaire de penser aux problèmes du passé qui pourraient survenir dans la phase suivante. Ce modèle ne fonctionne pas correctement s'il reste des problèmes à l'étape précédente. La nature séquentielle du modèle ne nous permet pas de revenir en arrière et d'annuler ou de refaire nos actions.
Ce modèle est le mieux adapté lorsque les développeurs ont déjà conçu et développé des logiciels similaires dans le passé et connaissent tous ses domaines.
Modèle itératif
Ce modèle conduit le processus de développement logiciel par itérations. Il projette le processus de développement de manière cyclique en répétant chaque étape après chaque cycle du processus SDLC.
Le logiciel est d'abord développé à très petite échelle et toutes les étapes sont suivies qui sont prises en considération. Ensuite, à chaque itération suivante, davantage de fonctionnalités et de modules sont conçus, codés, testés et ajoutés au logiciel. Chaque cycle produit un logiciel, qui est complet en lui-même et qui a plus de fonctionnalités et de capacités que celui du précédent.
Après chaque itération, l'équipe de direction peut travailler sur la gestion des risques et se préparer à la prochaine itération. Étant donné qu'un cycle comprend une petite partie de l'ensemble du processus logiciel, il est plus facile de gérer le processus de développement, mais il consomme plus de ressources.
Modèle en spirale
Le modèle en spirale est une combinaison du modèle itératif et de l'un des modèles SDLC. Cela peut être vu comme si vous choisissez un modèle SDLC et le combinez avec un processus cyclique (modèle itératif).
Ce modèle considère le risque, qui passe souvent inaperçu par la plupart des autres modèles. Le modèle commence par déterminer les objectifs et les contraintes du logiciel au début d'une itération. La phase suivante est le prototypage du logiciel. Cela comprend l'analyse des risques. Ensuite, un modèle SDLC standard est utilisé pour créer le logiciel. Dans la quatrième phase du plan de la prochaine itération est préparé.
V - modèle
L'inconvénient majeur du modèle de cascade est que nous ne passons à l'étape suivante que lorsque la précédente est terminée et qu'il n'y avait aucune chance de revenir en arrière si quelque chose ne va pas dans les étapes ultérieures. V-Model fournit des moyens de tester le logiciel à chaque étape de manière inverse.
À chaque étape, des plans de test et des cas de test sont créés pour vérifier et valider le produit conformément aux exigences de cette étape. Par exemple, lors de l'étape de collecte des exigences, l'équipe de test prépare tous les cas de test en correspondance avec les exigences. Plus tard, lorsque le produit est développé et est prêt pour les tests, les cas de test de cette étape vérifient le logiciel par rapport à sa validité par rapport aux exigences à ce stade.
Cela permet à la fois la vérification et la validation d'aller en parallèle. Ce modèle est également appelé modèle de vérification et de validation.
Modèle Big Bang
Ce modèle est le modèle le plus simple dans sa forme. Cela nécessite peu de planification, beaucoup de programmation et beaucoup de fonds. Ce modèle est conceptualisé autour du big bang de l'univers. Comme le disent les scientifiques, après le Big Bang, de nombreuses galaxies, planètes et étoiles ont évolué comme un événement. De même, si nous réunissons beaucoup de programmes et de fonds, vous pouvez obtenir le meilleur logiciel.
Pour ce modèle, très peu de planification est nécessaire. Il ne suit aucun processus, ou parfois le client n'est pas sûr des exigences et des besoins futurs. Les exigences d'entrée sont donc arbitraires.
Ce modèle n'est pas adapté aux grands projets logiciels mais bon pour l'apprentissage et l'expérimentation.
Pour une lecture approfondie sur SDLC et ses différents modèles, cliquez ici.
Le modèle de travail d'une entreprise informatique engagée dans le développement de logiciels peut être vu divisé en deux parties:
- Création de logiciels
- Gestion de projets logiciels
Un projet est une tâche bien définie, qui est un ensemble de plusieurs opérations effectuées afin d'atteindre un objectif (par exemple, le développement et la livraison de logiciels). Un projet peut être caractérisé comme:
- Chaque projet peut avoir un objectif unique et distinct.
- Le projet n'est pas une activité de routine ou des opérations quotidiennes.
- Le projet est livré avec une heure de début et une heure de fin.
- Le projet se termine lorsque son objectif est atteint, il s'agit donc d'une phase temporaire dans la vie d'une organisation.
- Le projet a besoin de ressources adéquates en termes de temps, de main-d’œuvre, de financement, de matériel et de banque de connaissances.
Projet logiciel
Un projet logiciel est la procédure complète de développement logiciel, de la collecte des exigences aux tests et à la maintenance, effectuée selon les méthodologies d'exécution, dans une période de temps spécifiée pour réaliser le produit logiciel prévu.
Besoin de gestion de projet logiciel
Le logiciel est considéré comme un produit intangible. Le développement logiciel est une sorte de tout nouveau courant dans les affaires mondiales et il y a très peu d'expérience dans la création de produits logiciels. La plupart des logiciels sont conçus sur mesure pour répondre aux besoins du client. Le plus important est que la technologie sous-jacente change et progresse si fréquemment et rapidement que l'expérience d'un produit peut ne pas être appliquée à l'autre. Toutes ces contraintes commerciales et environnementales entraînent des risques dans le développement de logiciels, il est donc essentiel de gérer efficacement les projets logiciels.
L'image ci-dessus montre trois contraintes pour les projets logiciels. C'est un élément essentiel de l'organisation logicielle pour fournir un produit de qualité, maintenir le coût dans les limites du budget du client et livrer le projet comme prévu. Plusieurs facteurs, internes et externes, peuvent avoir un impact sur ce triangle à triple contrainte. L'un des trois facteurs peut avoir un impact important sur les deux autres.
Par conséquent, la gestion de projet logiciel est essentielle pour intégrer les exigences des utilisateurs ainsi que les contraintes de budget et de temps.
Chef de projet logiciel
Un chef de projet logiciel est une personne qui assume la responsabilité de l'exécution du projet logiciel. Le chef de projet logiciel est parfaitement conscient de toutes les phases du SDLC que le logiciel passerait. Le chef de projet ne peut jamais s'impliquer directement dans la production du produit final, mais il contrôle et gère les activités impliquées dans la production.
Un chef de projet surveille étroitement le processus de développement, prépare et exécute divers plans, organise les ressources nécessaires et adéquates, maintient la communication entre tous les membres de l'équipe afin de résoudre les problèmes de coût, de budget, de ressources, de temps, de qualité et de satisfaction du client.
Voyons quelques responsabilités qu'un chef de projet assume -
Gérer des gens
- Agir en tant que chef de projet
- Lésion avec les parties prenantes
- Gérer les ressources humaines
- Mettre en place une hiérarchie de reporting, etc.
Gestion de projet
- Définition et configuration du périmètre du projet
- Gérer les activités de gestion de projet
- Suivi des progrès et des performances
- Analyse des risques à chaque phase
- Prendre les mesures nécessaires pour éviter ou sortir des problèmes
- Agir en tant que porte-parole du projet
Activités de gestion de logiciels
La gestion de projet logiciel comprend un certain nombre d'activités, qui comprend la planification du projet, le choix de la portée du produit logiciel, l'estimation du coût en divers termes, la planification des tâches et des événements et la gestion des ressources. Les activités de gestion de projet peuvent inclure:
- Project Planning
- Scope Management
- Project Estimation
Planification de projet
La planification de projet logiciel est une tâche qui est effectuée avant que la production du logiciel ne démarre réellement. Il est là pour la production de logiciels mais n'implique aucune activité concrète ayant un lien direct avec la production de logiciels; il s'agit plutôt d'un ensemble de processus multiples, ce qui facilite la production de logiciels. La planification du projet peut inclure les éléments suivants:
Gestion de la portée
Il définit la portée du projet; cela inclut toutes les activités, le processus doit être fait afin de créer un produit logiciel livrable. La gestion de la portée est essentielle car elle crée les limites du projet en définissant clairement ce qui serait fait dans le projet et ce qui ne serait pas fait. Cela rend le projet pour contenir des tâches limitées et quantifiables, qui peuvent facilement être documentées et à son tour évite les dépassements de coûts et de temps.
Lors de la gestion de la portée du projet, il est nécessaire de -
- Définir la portée
- Décider de sa vérification et de son contrôle
- Divisez le projet en plusieurs parties plus petites pour faciliter la gestion.
- Vérifiez la portée
- Contrôler le périmètre en intégrant les changements au périmètre
Estimation du projet
Pour une gestion efficace, une estimation précise des différentes mesures est indispensable. Avec une estimation correcte, les gestionnaires peuvent gérer et contrôler le projet de manière plus efficace et efficiente.
L'estimation du projet peut impliquer les éléments suivants:
- Software size estimation
La taille du logiciel peut être estimée soit en termes de KLOC (Kilo Line of Code) ou en calculant le nombre de points de fonction dans le logiciel. Les lignes de code dépendent des pratiques de codage et les points de fonction varient selon les besoins de l'utilisateur ou du logiciel.
- Effort estimation
Les gestionnaires évaluent les efforts en termes de besoins en personnel et d'heures de travail nécessaires pour produire le logiciel. Pour l'estimation de l'effort, la taille du logiciel doit être connue. Cela peut être dérivé de l'expérience des gestionnaires, les données historiques de l'organisation ou la taille du logiciel peuvent être converties en efforts en utilisant certaines formules standard.
- Time estimation
Une fois la taille et les efforts estimés, le temps requis pour produire le logiciel peut être estimé. Les efforts requis sont répartis en sous-catégories selon les spécifications des exigences et l'interdépendance des divers composants du logiciel. Les tâches logicielles sont divisées en tâches, activités ou événements plus petits par Work Breakthrough Structure (WBS). Les tâches sont planifiées au jour le jour ou en mois calendaires.
La somme du temps requis pour accomplir toutes les tâches en heures ou en jours est le temps total investi pour terminer le projet.
- Cost estimation
Cela peut être considéré comme le plus difficile de tous car il dépend de plus d'éléments que n'importe lequel des précédents. Pour estimer le coût du projet, il est nécessaire de considérer -
- Taille du logiciel
- Qualité du logiciel
- Hardware
- Logiciels ou outils supplémentaires, licences, etc.
- Personnel qualifié avec des compétences spécifiques à la tâche
- Voyage impliqué
- Communication
- Formation et accompagnement
Techniques d'estimation de projet
Nous avons discuté de divers paramètres impliquant l'estimation du projet tels que la taille, l'effort, le temps et le coût.
Le chef de projet peut estimer les facteurs énumérés en utilisant deux techniques largement reconnues -
Technique de décomposition
Cette technique suppose le logiciel comme un produit de diverses compositions.
Il existe deux modèles principaux -
- Line of Code L'estimation est faite au nom du nombre de lignes de codes dans le produit logiciel.
- Function Points L'estimation est effectuée au nom du nombre de points de fonction dans le produit logiciel.
Technique d'estimation empirique
Cette technique utilise des formules dérivées empiriquement pour faire des estimations. Ces formules sont basées sur les LOC ou les PF.
- Putnam Model
Ce modèle est fait par Lawrence H. Putnam, qui est basé sur la distribution de fréquence de Norden (courbe de Rayleigh). Le modèle Putnam cartographie le temps et les efforts requis avec la taille du logiciel.
- COCOMO
COCOMO signifie COnstructive COst MOdel, développé par Barry W. Boehm. Il divise le produit logiciel en trois catégories de logiciels: organiques, semi-détachés et embarqués.
Planification du projet
La planification de projet dans un projet fait référence à la feuille de route de toutes les activités à réaliser avec l'ordre spécifié et dans les délais alloués à chaque activité. Les chefs de projet ont tendance à définir diverses tâches et les jalons du projet et à les organiser en tenant compte de divers facteurs. Ils recherchent les tâches se trouvant dans le chemin critique dans le calendrier, qui sont nécessaires pour terminer de manière spécifique (en raison de l'interdépendance des tâches) et strictement dans le temps imparti. L'arrangement des tâches hors du chemin critique est moins susceptible d'avoir un impact sur tout le calendrier du projet.
Pour planifier un projet, il est nécessaire de -
- Décomposez les tâches du projet en une forme plus petite et gérable
- Découvrez diverses tâches et corrigez-les
- Estimer le délai requis pour chaque tâche
- Divisez le temps en unités de travail
- Attribuer un nombre adéquat d'unités de travail pour chaque tâche
- Calculer le temps total requis pour le projet du début à la fin
La gestion des ressources
Tous les éléments utilisés pour développer un produit logiciel peuvent être considérés comme des ressources pour ce projet. Cela peut inclure les ressources humaines, les outils de production et les bibliothèques de logiciels.
Les ressources sont disponibles en quantité limitée et restent dans l'organisation en tant que pool d'actifs. La pénurie de ressources entrave le développement du projet et peut prendre du retard sur le calendrier. L'allocation de ressources supplémentaires augmente les coûts de développement à la fin. Il est donc nécessaire d'estimer et d'allouer des ressources adéquates pour le projet.
La gestion des ressources comprend -
- Définir le bon projet d'organisation en créant une équipe de projet et en attribuant des responsabilités à chaque membre de l'équipe
- Déterminer les ressources nécessaires à un stade particulier et leur disponibilité
- Gérez les ressources en générant des demandes de ressources lorsqu'elles sont nécessaires et en les désallouant lorsqu'elles ne sont plus nécessaires.
Gestion des risques du projet
La gestion des risques comprend toutes les activités liées à l'identification, l'analyse et la prise en compte des risques prévisibles et non prévisibles du projet. Le risque peut inclure les éléments suivants:
- Personnel expérimenté quittant le projet et l'arrivée du nouveau personnel.
- Changement de gestion organisationnelle.
- Changement d'exigence ou mauvaise interprétation de l'exigence.
- Sous-estimation du temps et des ressources nécessaires.
- Changements technologiques, changements environnementaux, concurrence commerciale.
Processus de gestion des risques
Les activités suivantes sont impliquées dans le processus de gestion des risques:
- Identification - Prenez note de tous les risques possibles pouvant survenir dans le cadre du projet.
- Categorize - Catégoriser les risques connus en intensité de risque élevée, moyenne et faible en fonction de leur impact possible sur le projet.
- Manage - Analyser la probabilité d'occurrence des risques à différentes phases. Faites un plan pour éviter ou faire face aux risques. Essayez de minimiser leurs effets secondaires.
- Monitor - Surveillez de près les risques potentiels et leurs premiers symptômes. Surveillez également les effets des mesures prises pour les atténuer ou les éviter.
Exécution et suivi de projet
Dans cette phase, les tâches décrites dans les plans de projet sont exécutées selon leur calendrier.
L'exécution doit être surveillée afin de vérifier si tout se passe comme prévu. Le suivi consiste à observer pour vérifier la probabilité de risque et à prendre des mesures pour faire face au risque ou signaler l'état de diverses tâches.
Ces mesures comprennent -
- Activity Monitoring - Toutes les activités planifiées dans une tâche peuvent être surveillées au jour le jour. Lorsque toutes les activités d'une tâche sont terminées, elle est considérée comme terminée.
- Status Reports - Les rapports contiennent l'état des activités et des tâches accomplies dans un laps de temps donné, généralement une semaine. Le statut peut être marqué comme terminé, en attente ou en cours de travail, etc.
- Milestones Checklist - Chaque projet est divisé en plusieurs phases où des tâches majeures sont effectuées (jalons) en fonction des phases du SDLC. Cette liste de contrôle des jalons est préparée une fois toutes les quelques semaines et fait état de l'état des jalons.
Gestion de la communication de projet
Une communication efficace joue un rôle essentiel dans la réussite d'un projet. Il comble les écarts entre le client et l'organisation, entre les membres de l'équipe ainsi que d'autres parties prenantes du projet telles que les fournisseurs de matériel.
La communication peut être orale ou écrite. Le processus de gestion de la communication peut comporter les étapes suivantes:
- Planning - Cette étape comprend l'identification de tous les acteurs du projet et le mode de communication entre eux. Il considère également si des moyens de communication supplémentaires sont nécessaires.
- Sharing - Après avoir déterminé divers aspects de la planification, le gestionnaire se concentre sur le partage d'informations correctes avec la bonne personne au bon moment. Cela permet à toutes les personnes impliquées dans le projet d'être au courant de l'avancement du projet et de son statut.
- Feedback - Les chefs de projet utilisent diverses mesures et mécanismes de retour d'information et créent des rapports d'état et de performance. Ce mécanisme garantit que les contributions des différentes parties prenantes parviennent au chef de projet en tant que commentaires.
- Closure - A la fin de chaque événement majeur, à la fin d'une phase de SDLC ou à la fin du projet lui-même, la clôture administrative est formellement annoncée pour mettre à jour chaque partie prenante par envoi de courrier électronique, en diffusant une copie papier du document ou par tout autre moyen de communication efficace.
Après la clôture, l'équipe passe à la phase ou au projet suivant.
Gestion de la configuration
La gestion de la configuration est un processus de suivi et de contrôle des modifications du logiciel en termes d'exigences, de conception, de fonctions et de développement du produit.
L'IEEE le définit comme «le processus d'identification et de définition des éléments dans le système, de contrôle du changement de ces éléments tout au long de leur cycle de vie, d'enregistrement et de rapport de l'état des éléments et des demandes de changement, et de vérification de l'exhaustivité et de l'exactitude des éléments».
En général, une fois que le SRS est finalisé, il y a moins de chance d'exiger des changements de la part de l'utilisateur. S'ils se produisent, les changements ne sont abordés qu'avec l'approbation préalable de la direction supérieure, car il existe une possibilité de dépassement des coûts et des délais.
Ligne de base
Une phase de SDLC est supposée terminée si elle est de base, c'est-à-dire que la ligne de base est une mesure qui définit l'exhaustivité d'une phase. Une phase est établie lorsque toutes les activités qui la concernent sont terminées et bien documentées. S'il ne s'agissait pas de la phase finale, sa sortie serait utilisée dans la phase immédiate suivante.
La gestion de la configuration est une discipline de l'administration de l'organisation, qui s'occupe de l'occurrence de tout changement (processus, exigence, technologique, stratégique, etc.) après qu'une phase est établie. CM surveille toutes les modifications apportées au logiciel.
Le contrôle des changements
Le contrôle des modifications est fonction de la gestion de la configuration, qui garantit que toutes les modifications apportées au système logiciel sont cohérentes et effectuées conformément aux règles et réglementations organisationnelles.
Un changement dans la configuration du produit passe par les étapes suivantes -
Identification- Une demande de changement arrive d'une source interne ou externe. Lorsque la demande de changement est formellement identifiée, elle est correctement documentée.
Validation - La validité de la demande de changement est vérifiée et sa procédure de traitement est confirmée.
Analysis- L'impact de la demande de changement est analysé en termes de calendrier, de coût et d'efforts requis. L'impact global du changement potentiel sur le système est analysé.
Control- Si le changement envisagé a un impact sur trop d'entités dans le système ou est inévitable, il est obligatoire d'obtenir l'approbation des autorités supérieures avant que le changement ne soit incorporé dans le système. Il est décidé si le changement vaut la peine d'être incorporé ou non. Dans le cas contraire, la demande de modification est formellement refusée.
Execution - Si la phase précédente détermine d'exécuter la demande de changement, cette phase prend les mesures appropriées pour exécuter le changement, effectue une révision approfondie si nécessaire.
Close request- La modification est vérifiée pour une mise en œuvre correcte et une fusion avec le reste du système. Ce changement nouvellement incorporé dans le logiciel est correctement documenté et la demande est formellement close.
Outils de gestion de projet
Le risque et l'incertitude sont multipliés par rapport à la taille du projet, même lorsque le projet est développé selon des méthodologies établies.
Il existe des outils disponibles qui aident à une gestion de projet efficace. Quelques-uns sont décrits -
Diagramme de Gantt
Les diagrammes de Gantt ont été conçus par Henry Gantt (1917). Il représente le calendrier du projet par rapport aux périodes. Il s'agit d'un diagramme à barres horizontales avec des barres représentant les activités et le temps prévus pour les activités du projet.
Graphique PERT
Le tableau PERT (Program Evaluation & Review Technique) est un outil qui décrit le projet sous forme de diagramme de réseau. Il est capable de représenter graphiquement les principaux événements du projet de manière parallèle et consécutive. Les événements, qui se produisent l'un après l'autre, montrent la dépendance du dernier événement par rapport au précédent.
Les événements sont affichés sous forme de nœuds numérotés. Ils sont reliés par des flèches étiquetées représentant la séquence des tâches du projet.
Histogramme des ressources
Il s'agit d'un outil graphique qui contient une barre ou un graphique représentant le nombre de ressources (généralement du personnel qualifié) nécessaires au fil du temps pour un événement (ou une phase) de projet. L'histogramme des ressources est un outil efficace pour la planification et la coordination du personnel.
Analyse du chemin critique
Cet outil est utile pour reconnaître les tâches interdépendantes dans le projet. Cela aide également à trouver le chemin le plus court ou le chemin critique pour mener à bien le projet. Comme le diagramme PERT, chaque événement se voit attribuer une période de temps spécifique. Cet outil montre la dépendance de l'événement en supposant qu'un événement peut passer au suivant uniquement si le précédent est terminé.
Les événements sont organisés en fonction de leur heure de début la plus proche possible. Le chemin entre le nœud de début et de fin est un chemin critique qui ne peut pas être réduit davantage et tous les événements doivent être exécutés dans le même ordre.
Les exigences logicielles sont la description des caractéristiques et des fonctionnalités du système cible. Les exigences traduisent les attentes des utilisateurs vis-à-vis du produit logiciel. Les exigences peuvent être évidentes ou cachées, connues ou inconnues, attendues ou inattendues du point de vue du client.
Ingénierie des exigences
Le processus pour rassembler les exigences logicielles du client, les analyser et les documenter est connu sous le nom d'ingénierie des exigences.
Le but de l'ingénierie des exigences est de développer et de maintenir un document sophistiqué et descriptif de «spécification des exigences système».
Processus d'ingénierie des exigences
Il s'agit d'un processus en quatre étapes, qui comprend:
- Étude de faisabilité
- Rassemblement des exigences
- Spécification des exigences logicielles
- Validation des exigences logicielles
Voyons brièvement le processus -
Étude de faisabilité
Lorsque le client s'approche de l'organisation pour obtenir le produit souhaité développé, il se fait une idée approximative de toutes les fonctions que le logiciel doit exécuter et de toutes les fonctionnalités attendues du logiciel.
En se référant à ces informations, les analystes effectuent une étude détaillée pour savoir si le système souhaité et ses fonctionnalités sont réalisables à développer.
Cette étude de faisabilité est centrée sur l'objectif de l'organisation. Cette étude analyse si le produit logiciel peut être concrètement matérialisé en termes de mise en œuvre, de contribution du projet à l'organisation, de contraintes de coût et selon les valeurs et objectifs de l'organisation. Il explore les aspects techniques du projet et du produit tels que la convivialité, la maintenabilité, la productivité et la capacité d'intégration.
Le résultat de cette phase devrait être un rapport d'étude de faisabilité qui devrait contenir des commentaires et des recommandations adéquats pour la direction quant à savoir si le projet doit être entrepris ou non.
Rassemblement des exigences
Si le rapport de faisabilité est positif pour entreprendre le projet, la phase suivante commence par la collecte des exigences de l'utilisateur. Les analystes et les ingénieurs communiquent avec le client et les utilisateurs finaux pour connaître leurs idées sur ce que le logiciel doit fournir et les fonctionnalités qu'ils souhaitent inclure dans le logiciel.
Spécification des exigences logicielles
SRS est un document créé par l'analyste système après que les exigences ont été collectées auprès de diverses parties prenantes.
SRS définit comment le logiciel prévu interagira avec le matériel, les interfaces externes, la vitesse de fonctionnement, le temps de réponse du système, la portabilité du logiciel sur diverses plates-formes, la maintenabilité, la vitesse de récupération après un crash, la sécurité, la qualité, les limitations, etc.
Les exigences reçues du client sont rédigées en langage naturel. Il est de la responsabilité de l'analyste système de documenter les exigences dans un langage technique afin qu'elles puissent être comprises et utiles par l'équipe de développement logiciel.
SRS devrait proposer les fonctionnalités suivantes:
- Les exigences des utilisateurs sont exprimées en langage naturel.
- Les exigences techniques sont exprimées dans un langage structuré, utilisé à l'intérieur de l'organisation.
- La description de la conception doit être écrite en pseudo-code.
- Format des formulaires et des impressions d'écran GUI.
- Notations conditionnelles et mathématiques pour les DFD, etc.
Validation des exigences logicielles
Une fois les spécifications des exigences développées, les exigences mentionnées dans ce document sont validées. L'utilisateur peut demander une solution illégale et peu pratique ou des experts peuvent interpréter les exigences de manière incorrecte. Cela se traduit par une énorme augmentation du coût s'il n'est pas étouffé dans l'œuf. Les exigences peuvent être vérifiées par rapport aux conditions suivantes -
- S'ils peuvent être mis en œuvre pratiquement
- S'ils sont valides et selon la fonctionnalité et le domaine du logiciel
- S'il y a des ambiguïtés
- S'ils sont complets
- S'ils peuvent être démontrés
Processus d'élicitation des besoins
Le processus d'élicitation des exigences peut être décrit à l'aide du diagramme suivant:
- Requirements gathering - Les développeurs discutent avec le client et les utilisateurs finaux et connaissent leurs attentes par rapport au logiciel.
- Organizing Requirements - Les développeurs hiérarchisent et organisent les exigences par ordre d'importance, d'urgence et de commodité.
Negotiation & discussion - Si les exigences sont ambiguës ou s'il y a des conflits dans les exigences des différentes parties prenantes, si elles le sont, elles sont alors négociées et discutées avec les parties prenantes. Les exigences peuvent alors être hiérarchisées et raisonnablement compromises.
Les exigences proviennent de diverses parties prenantes. Pour supprimer l'ambiguïté et les conflits, ils sont discutés pour plus de clarté et d'exactitude. Les exigences irréalistes sont raisonnablement compromises.
- Documentation - Toutes les exigences formelles et informelles, fonctionnelles et non fonctionnelles sont documentées et mises à disposition pour le traitement de la phase suivante.
Techniques d'élicitation des exigences
L'élicitation des exigences est le processus qui permet de connaître les exigences d'un système logiciel prévu en communiquant avec le client, les utilisateurs finaux, les utilisateurs du système et d'autres personnes qui ont un intérêt dans le développement du système logiciel.
Il existe différentes manières de découvrir les exigences
Entrevues
Les entretiens sont un moyen efficace pour recueillir les exigences. L'organisation peut mener plusieurs types d'entretiens tels que:
- Entretiens structurés (fermés), où chaque information à recueillir est décidée à l'avance, ils suivent fermement le modèle et le sujet de discussion.
- Entretiens non structurés (ouverts), où les informations à recueillir ne sont pas décidées à l'avance, plus flexibles et moins biaisés.
- Entretiens oraux
- Entretiens écrits
- Entretiens individuels qui ont lieu entre deux personnes de l'autre côté de la table.
- Entretiens de groupe qui ont lieu entre des groupes de participants. Ils aident à découvrir toute exigence manquante car de nombreuses personnes sont impliquées.
Enquêtes
L'organisation peut mener des enquêtes auprès de diverses parties prenantes en interrogeant leurs attentes et leurs exigences par rapport au système à venir.
Questionnaires
Un document avec un ensemble prédéfini de questions objectives et des options respectives est remis à toutes les parties prenantes pour y répondre, qui sont collectées et compilées.
Une lacune de cette technique est que si une option pour un problème n'est pas mentionnée dans le questionnaire, le problème peut être laissé sans surveillance.
Analyse des tâches
Une équipe d'ingénieurs et de développeurs peut analyser l'opération pour laquelle le nouveau système est requis. Si le client dispose déjà d'un logiciel pour effectuer certaines opérations, il est étudié et les exigences du système proposé sont collectées.
Analyse de domaine
Chaque logiciel appartient à une catégorie de domaine. Les experts du domaine peuvent être d'une grande aide pour analyser les exigences générales et spécifiques.
Réflexion
Un débat informel a lieu entre les différentes parties prenantes et toutes leurs contributions sont enregistrées pour une analyse plus approfondie des besoins.
Prototypage
Le prototypage consiste à créer une interface utilisateur sans ajouter de fonctionnalités détaillées permettant à l'utilisateur d'interpréter les fonctionnalités du produit logiciel prévu. Cela permet de donner une meilleure idée des besoins. Si aucun logiciel n'est installé chez le client pour référence du développeur et que le client n'est pas au courant de ses propres exigences, le développeur crée un prototype basé sur les exigences initialement mentionnées. Le prototype est montré au client et les commentaires sont notés. Les commentaires des clients servent d'entrée pour la collecte des exigences.
Observation
Une équipe d'experts visite l'organisation ou le lieu de travail du client. Ils observent le fonctionnement réel des systèmes installés existants. Ils observent le flux de travail à la fin du client et comment les problèmes d'exécution sont traités. L'équipe elle-même tire quelques conclusions qui aident à former les exigences attendues du logiciel.
Caractéristiques des exigences logicielles
La collecte des exigences logicielles est la base de tout le projet de développement logiciel. Par conséquent, ils doivent être clairs, corrects et bien définis.
Une spécification complète des exigences logicielles doit être:
- Clear
- Correct
- Consistent
- Coherent
- Comprehensible
- Modifiable
- Verifiable
- Prioritized
- Unambiguous
- Traceable
- Source crédible
Logiciels requis
Nous devons essayer de comprendre quel type d'exigences peuvent survenir dans la phase d'élicitation des exigences et quels types d'exigences sont attendues du système logiciel.
Les exigences logicielles générales doivent être classées en deux catégories:
Exigences fonctionnelles
Les exigences, qui sont liées à l'aspect fonctionnel du logiciel, entrent dans cette catégorie.
Ils définissent les fonctions et fonctionnalités à l'intérieur et à partir du système logiciel.
Exemples -
- Option de recherche donnée à l'utilisateur pour rechercher à partir de diverses factures.
- L'utilisateur doit pouvoir envoyer n'importe quel rapport à la direction.
- Les utilisateurs peuvent être divisés en groupes et les groupes peuvent recevoir des droits distincts.
- Doit se conformer aux règles commerciales et aux fonctions administratives.
- Le logiciel est développé en gardant la compatibilité descendante intacte.
Prérogatives non fonctionnelles
Les exigences, qui ne sont pas liées à l'aspect fonctionnel du logiciel, entrent dans cette catégorie. Ce sont des caractéristiques implicites ou attendues du logiciel, dont les utilisateurs font l'hypothèse.
Les exigences non fonctionnelles comprennent -
- Security
- Logging
- Storage
- Configuration
- Performance
- Cost
- Interoperability
- Flexibility
- Reprise après sinistre
- Accessibility
Les exigences sont classées logiquement comme
- Must Have : Un logiciel ne peut pas être dit opérationnel sans eux.
- Should have : Amélioration des fonctionnalités du logiciel.
- Could have : Le logiciel peut toujours fonctionner correctement avec ces exigences.
- Wish list : Ces exigences ne correspondent à aucun objectif du logiciel.
Lors du développement d'un logiciel, «Must have» doit être implémenté, «should have» est un sujet de débat avec les parties prenantes et de négation, alors que «could have» et «wish list» peuvent être conservés pour les mises à jour logicielles.
Exigences de l'interface utilisateur
L'interface utilisateur est une partie importante de tout logiciel, matériel ou système hybride. Un logiciel est largement accepté s'il est -
- facile à utiliser
- réponse rapide
- gérer efficacement les erreurs opérationnelles
- fournissant une interface utilisateur simple mais cohérente
L'acceptation de l'utilisateur dépend principalement de la manière dont l'utilisateur peut utiliser le logiciel. L'interface utilisateur est le seul moyen pour les utilisateurs de percevoir le système. Un système logiciel performant doit également être équipé d'une interface utilisateur attrayante, claire, cohérente et réactive. Sinon, les fonctionnalités du système logiciel ne peuvent pas être utilisées de manière pratique. Un système est dit bon s'il fournit les moyens de l'utiliser efficacement. Les exigences d'interface utilisateur sont brièvement mentionnées ci-dessous -
- Présentation du contenu
- Navigation facile
- Interface simple
- Responsive
- Éléments d'interface cohérents
- Mécanisme de rétroaction
- Paramètres par défaut
- Mise en page ciblée
- Utilisation stratégique de la couleur et de la texture.
- Fournir des informations d'aide
- Approche centrée sur l'utilisateur
- Paramètres d'affichage basés sur les groupes.
Analyste système logiciel
L'analyste système dans une organisation informatique est une personne qui analyse les exigences du système proposé et s'assure que les exigences sont conçues et documentées correctement et correctement. Le rôle d'un analyste commence pendant la phase d'analyse logicielle du SDLC. Il est de la responsabilité de l'analyste de s'assurer que le logiciel développé répond aux exigences du client.
Les analystes système ont les responsabilités suivantes:
- Analyser et comprendre les exigences du logiciel prévu
- Comprendre comment le projet contribuera aux objectifs de l'organisation
- Identifier les sources d'exigence
- Validation de l'exigence
- Élaborer et mettre en œuvre un plan de gestion des exigences
- Documentation des exigences commerciales, techniques, de processus et de produit
- Coordination avec les clients pour hiérarchiser les exigences et éliminer les ambiguïtés
- Finaliser les critères d'acceptation avec le client et les autres parties prenantes
Métriques et mesures du logiciel
Les mesures logicielles peuvent être comprises comme un processus de quantification et de symbolisation de divers attributs et aspects d'un logiciel.
Les mesures logicielles fournissent des mesures pour divers aspects du processus logiciel et du produit logiciel.
Les mesures logicielles sont une exigence fondamentale du génie logiciel. Ils aident non seulement à contrôler le processus de développement logiciel, mais aussi à maintenir la qualité du produit final excellente.
Selon Tom DeMarco, un (ingénieur logiciel), «vous ne pouvez pas contrôler ce que vous ne pouvez pas mesurer.» Selon ses propos, l’importance des mesures logicielles est très claire.
Voyons quelques métriques logicielles:
Size Metrics - LOC (Lines of Code), principalement calculé en milliers de lignes de code source livrées, noté KLOC.
Le nombre de points de fonction mesure la fonctionnalité fournie par le logiciel. Le nombre de points de fonction définit la taille de l'aspect fonctionnel du logiciel.
- Complexity Metrics - La complexité cyclomatique de McCabe quantifie la limite supérieure du nombre de chemins indépendants dans un programme, qui est perçue comme la complexité du programme ou de ses modules. Il est représenté en termes de concepts de théorie des graphes en utilisant un graphe de flux de contrôle.
Quality Metrics - Les défauts, leurs types et causes, leurs conséquences, leur intensité et leurs implications définissent la qualité du produit.
Le nombre de défauts trouvés dans le processus de développement et le nombre de défauts signalés par le client après l'installation ou la livraison du produit chez le client définissent la qualité du produit.
- Process Metrics - Dans les différentes phases du SDLC, les méthodes et outils utilisés, les standards de l'entreprise et les performances de développement sont des métriques de processus logiciels.
- Resource Metrics - L'effort, le temps et les diverses ressources utilisées représentent des mesures pour la mesure des ressources.
La conception de logiciels est un processus pour transformer les exigences des utilisateurs en une forme appropriée, ce qui aide le programmeur dans le codage et la mise en œuvre de logiciels.
Pour évaluer les besoins des utilisateurs, un document SRS (Software Requirement Specification) est créé, tandis que pour le codage et la mise en œuvre, il existe un besoin d'exigences plus spécifiques et détaillées en termes de logiciels. La sortie de ce processus peut être directement utilisée dans l'implémentation dans les langages de programmation.
La conception logicielle est la première étape du SDLC (Software Design Life Cycle), qui déplace la concentration du domaine du problème au domaine de la solution. Il essaie de spécifier comment remplir les exigences mentionnées dans SRS.
Niveaux de conception de logiciels
La conception logicielle donne trois niveaux de résultats:
- Architectural Design - La conception architecturale est la version la plus abstraite du système. Il identifie le logiciel comme un système avec de nombreux composants interagissant les uns avec les autres. À ce niveau, les concepteurs se font une idée du domaine de solution proposé.
- High-level Design- La conception de haut niveau divise le concept de conception architecturale de «composant unique à entité multiple» en une vue moins abstraite des sous-systèmes et des modules et décrit leur interaction les uns avec les autres. La conception de haut niveau se concentre sur la façon dont le système et tous ses composants peuvent être mis en œuvre sous forme de modules. Il reconnaît la structure modulaire de chaque sous-système et leur relation et interaction entre eux.
- Detailed Design- La conception détaillée traite de la partie mise en œuvre de ce qui est considéré comme un système et de ses sous-systèmes dans les deux conceptions précédentes. Il est plus détaillé sur les modules et leurs implémentations. Il définit la structure logique de chaque module et leurs interfaces pour communiquer avec d'autres modules.
La modularisation
La modularisation est une technique permettant de diviser un système logiciel en plusieurs modules discrets et indépendants, qui sont censés être capables d'exécuter des tâches de manière indépendante. Ces modules peuvent fonctionner comme des constructions de base pour l'ensemble du logiciel. Les concepteurs ont tendance à concevoir des modules de manière à ce qu'ils puissent être exécutés et / ou compilés séparément et indépendamment.
La conception modulaire suit involontairement les règles de la stratégie de résolution de problèmes «diviser pour conquérir», car il existe de nombreux autres avantages liés à la conception modulaire d'un logiciel.
Avantage de la modularisation:
- Les petits composants sont plus faciles à entretenir
- Le programme peut être divisé en fonction des aspects fonctionnels
- Le niveau d'abstraction souhaité peut être introduit dans le programme
- Les composants à forte cohésion peuvent être réutilisés
- Une exécution simultanée peut être rendue possible
- Souhaité du point de vue de la sécurité
Concurrence
À l'époque, tous les logiciels sont destinés à être exécutés séquentiellement. Par exécution séquentielle, nous entendons que l'instruction codée sera exécutée l'une après l'autre, ce qui implique qu'une seule partie du programme est activée à un moment donné. Disons qu'un logiciel a plusieurs modules, alors un seul de tous les modules peut être trouvé actif à tout moment de l'exécution.
Dans la conception de logiciels, la concurrence est mise en œuvre en divisant le logiciel en plusieurs unités d'exécution indépendantes, comme des modules, et en les exécutant en parallèle. En d'autres termes, la concurrence permet au logiciel d'exécuter plus d'une partie de code en parallèle les unes par rapport aux autres.
Il est nécessaire que les programmeurs et les concepteurs reconnaissent ces modules, qui peuvent être exécutés en parallèle.
Exemple
La fonction de vérification orthographique du traitement de texte est un module de logiciel qui fonctionne avec le traitement de texte lui-même.
Couplage et cohésion
Lorsqu'un logiciel est modulaire, ses tâches sont divisées en plusieurs modules en fonction de certaines caractéristiques. Comme nous le savons, les modules sont un ensemble d'instructions assemblées afin d'accomplir certaines tâches. Ils sont cependant considérés comme une seule entité mais peuvent se référer les uns aux autres pour travailler ensemble. Il existe des mesures permettant de mesurer la qualité d'une conception de modules et leur interaction entre eux. Ces mesures sont appelées couplage et cohésion.
Cohésion
La cohésion est une mesure qui définit le degré d'intra-fiabilité au sein des éléments d'un module. Plus la cohésion est grande, meilleure est la conception du programme.
Il existe sept types de cohésion, à savoir -
- Co-incidental cohesion -Il s'agit d'une cohésion non planifiée et aléatoire, qui pourrait être le résultat de la décomposition du programme en modules plus petits dans un souci de modularisation. Parce qu'il n'est pas planifié, il peut prêter à confusion pour les programmeurs et n'est généralement pas accepté.
- Logical cohesion - Lorsque des éléments classés logiquement sont rassemblés dans un module, on parle de cohésion logique.
- emporal Cohesion - Lorsque des éléments du module sont organisés de telle sorte qu'ils sont traités à un moment similaire dans le temps, on parle de cohésion temporelle.
- Procedural cohesion - Lorsque des éléments du module sont regroupés, qui sont exécutés séquentiellement afin d'exécuter une tâche, on parle de cohésion procédurale.
- Communicational cohesion - Lorsque des éléments du module sont regroupés, qui sont exécutés séquentiellement et travaillent sur les mêmes données (informations), on parle de cohésion communicationnelle.
- Sequential cohesion - Lorsque des éléments du module sont regroupés parce que la sortie d'un élément sert d'entrée à un autre et ainsi de suite, on parle de cohésion séquentielle.
- Functional cohesion - Il est considéré comme le plus haut degré de cohésion et il est très attendu. Les éléments du module en cohésion fonctionnelle sont regroupés car ils contribuent tous à une seule fonction bien définie. Il peut également être réutilisé.
Couplage
Le couplage est une mesure qui définit le niveau d'interdépendance entre les modules d'un programme. Il indique à quel niveau les modules interfèrent et interagissent les uns avec les autres. Plus le couplage est bas, meilleur est le programme.
Il existe cinq niveaux de couplage, à savoir -
- Content coupling - Lorsqu'un module peut accéder directement, modifier ou faire référence au contenu d'un autre module, on parle de couplage au niveau du contenu.
- Common coupling- Lorsque plusieurs modules ont un accès en lecture et en écriture à certaines données globales, on parle de couplage commun ou global.
- Control coupling- Deux modules sont dits couplés en contrôle si l'un d'eux décide de la fonction de l'autre module ou modifie son flux d'exécution.
- Stamp coupling- Lorsque plusieurs modules partagent une structure de données commune et travaillent sur une partie différente de celle-ci, on parle de couplage de timbres.
- Data coupling- Le couplage de données se produit lorsque deux modules interagissent l'un avec l'autre au moyen de la transmission de données (en tant que paramètre). Si un module transmet la structure de données en tant que paramètre, le module récepteur doit utiliser tous ses composants.
Idéalement, aucun couplage n'est considéré comme le meilleur.
Vérification de la conception
Le résultat du processus de conception de logiciel est la documentation de conception, des pseudo codes, des diagrammes logiques détaillés, des diagrammes de processus et une description détaillée de toutes les exigences fonctionnelles ou non fonctionnelles.
La phase suivante, qui est la mise en œuvre du logiciel, dépend de toutes les sorties mentionnées ci-dessus.
Il devient alors nécessaire de vérifier la sortie avant de passer à la phase suivante. Plus une erreur est détectée tôt, mieux c'est ou elle peut ne pas être détectée avant le test du produit. Si les résultats de la phase de conception sont sous forme de notation formelle, alors leurs outils associés pour la vérification doivent être utilisés, sinon un examen approfondi de la conception peut être utilisé pour la vérification et la validation.
Grâce à une approche de vérification structurée, les examinateurs peuvent détecter les défauts qui pourraient être causés par l'ignorance de certaines conditions. Un bon examen de la conception est important pour une bonne conception, précision et qualité du logiciel.
L'analyse et la conception de logiciels comprennent toutes les activités qui aident à transformer la spécification des exigences en implémentation. Les spécifications des exigences spécifient toutes les attentes fonctionnelles et non fonctionnelles du logiciel. Ces spécifications d'exigences se présentent sous la forme de documents lisibles et compréhensibles par l'homme, auxquels un ordinateur n'a rien à voir.
L'analyse et la conception de logiciels constituent l'étape intermédiaire, qui permet aux exigences lisibles par l'homme d'être transformées en code réel.
Voyons quelques outils d'analyse et de conception utilisés par les concepteurs de logiciels:
Diagramme de flux de données
Le diagramme de flux de données est une représentation graphique du flux de données dans un système d'information. Il est capable de représenter le flux de données entrant, le flux de données sortant et les données stockées. Le DFD ne mentionne rien sur la manière dont les données circulent dans le système.
Il existe une différence importante entre DFD et Flowchart. L'organigramme décrit le flux de contrôle dans les modules de programme. Les DFD décrivent le flux de données dans le système à différents niveaux. DFD ne contient aucun élément de contrôle ou de branche.
Types de DFD
Les diagrammes de flux de données sont logiques ou physiques.
- Logical DFD - Ce type de DFD se concentre sur le processus du système et le flux de données dans le système. Par exemple, dans un système logiciel bancaire, comment les données sont déplacées entre différentes entités.
- Physical DFD- Ce type de DFD montre comment le flux de données est réellement implémenté dans le système. Il est plus précis et proche de la mise en œuvre.
Composants DFD
DFD peut représenter la source, la destination, le stockage et le flux de données à l'aide de l'ensemble de composants suivant -
- Entities- Les entités sont la source et la destination des données d'information. Les entités sont représentées par des rectangles avec leurs noms respectifs.
- Process - Les activités et mesures prises sur les données sont représentées par des rectangles circulaires ou arrondis.
- Data Storage - Il existe deux variantes de stockage de données - il peut être représenté soit comme un rectangle avec l'absence des deux côtés plus petits, soit comme un rectangle à côtés ouverts avec un seul côté manquant.
- Data Flow- Le mouvement des données est indiqué par des flèches pointues. Le mouvement des données est indiqué de la base de la flèche comme source vers la tête de la flèche comme destination.
Niveaux de DFD
- Level 0- Le DFD de niveau d'abstraction le plus élevé est connu sous le nom de DFD de niveau 0, qui représente l'ensemble du système d'information sous la forme d'un diagramme dissimulant tous les détails sous-jacents. Les DFD de niveau 0 sont également appelés DFD de niveau contextuel.
- Level 1- Le DFD de niveau 0 est divisé en DFD de niveau 1 plus spécifiques. Le DFD de niveau 1 décrit les modules de base du système et le flux de données entre divers modules. Le DFD de niveau 1 mentionne également les processus de base et les sources d'information.
Level 2 - À ce niveau, DFD montre comment les données circulent à l'intérieur des modules mentionnés au niveau 1.
Les DFD de niveau supérieur peuvent être transformés en DFD de niveau inférieur plus spécifiques avec un niveau de compréhension plus approfondi à moins que le niveau de spécification souhaité ne soit atteint.
Diagrammes de structure
Le diagramme de structure est un diagramme dérivé du diagramme de flux de données. Il représente le système plus en détail que DFD. Il décompose l'ensemble du système en modules fonctionnels les plus bas, décrit les fonctions et sous-fonctions de chaque module du système avec plus de détails que DFD.
Le diagramme de structure représente la structure hiérarchique des modules. À chaque couche, une tâche spécifique est effectuée.
Voici les symboles utilisés dans la construction des diagrammes de structure -
- Module- Il représente un processus ou un sous-programme ou une tâche. Un module de contrôle se branche sur plus d'un sous-module. Les modules de bibliothèque sont réutilisables et invocables depuis n'importe quel module.
- Condition- Il est représenté par un petit losange à la base du module. Il montre que le module de commande peut sélectionner n'importe quel sous-programme en fonction de certaines conditions.
- Jump - Une flèche est représentée pointant à l'intérieur du module pour indiquer que la commande sautera au milieu du sous-module.
- Loop- Une flèche courbe représente la boucle dans le module. Tous les sous-modules couverts par l'exécution en boucle du module.
- Data flow - Une flèche dirigée avec un cercle vide à la fin représente le flux de données.
- Control flow - Une flèche dirigée avec un cercle plein à la fin représente le flux de contrôle.
Diagramme HIPO
Le diagramme HIPO (Hierarchical Input Process Output) est une combinaison de deux méthodes organisées pour analyser le système et fournir les moyens de documentation. Le modèle HIPO a été développé par IBM en 1970.
Le diagramme HIPO représente la hiérarchie des modules dans le système logiciel. Analyst utilise le diagramme HIPO afin d'obtenir une vue de haut niveau des fonctions du système. Il décompose les fonctions en sous-fonctions de manière hiérarchique. Il décrit les fonctions exécutées par le système.
Les diagrammes HIPO sont utiles à des fins de documentation. Leur représentation graphique permet aux concepteurs et aux gestionnaires de se faire une idée plus simple de la structure du système.
Contrairement au diagramme IPO (Input Process Output), qui représente le flux de contrôle et de données dans un module, HIPO ne fournit aucune information sur le flux de données ou le flux de contrôle.
Exemple
Les deux parties du diagramme HIPO, de la présentation hiérarchique et du diagramme IPO sont utilisées pour la conception de la structure du programme logiciel ainsi que pour sa documentation.
Anglais structuré
La plupart des programmeurs ne sont pas conscients de la vue d'ensemble des logiciels et ne comptent donc que sur ce que leurs responsables leur disent de faire. Il est de la responsabilité de la direction logicielle supérieure de fournir des informations précises aux programmeurs pour développer un code précis mais rapide.
D'autres formes de méthodes, qui utilisent des graphiques ou des diagrammes, peuvent être parfois interprétées différemment par différentes personnes.
Par conséquent, les analystes et les concepteurs du logiciel proposent des outils tels que l'anglais structuré. Ce n'est rien d'autre que la description de ce qui est requis pour coder et comment le coder. L'anglais structuré aide le programmeur à écrire du code sans erreur.
D'autres formes de méthodes, qui utilisent des graphiques ou des diagrammes, peuvent être parfois interprétées différemment par différentes personnes. Ici, l'anglais structuré et le pseudo-code essaient d'atténuer ce manque de compréhension.
L'anglais structuré est le Il utilise des mots anglais simples dans le paradigme de programmation structurée. Ce n'est pas le code ultime mais une sorte de description de ce qui est nécessaire pour coder et comment le coder. Voici quelques jetons de programmation structurée.
IF-THEN-ELSE,
DO-WHILE-UNTIL
Analyst utilise la même variable et le même nom de données, qui sont stockés dans le dictionnaire de données, ce qui simplifie considérablement l'écriture et la compréhension du code.
Exemple
Nous prenons le même exemple d'authentification client dans l'environnement d'achat en ligne. Cette procédure d'authentification du client peut être rédigée en anglais structuré sous la forme:
Enter Customer_Name
SEEK Customer_Name in Customer_Name_DB file
IF Customer_Name found THEN
Call procedure USER_PASSWORD_AUTHENTICATE()
ELSE
PRINT error message
Call procedure NEW_CUSTOMER_REQUEST()
ENDIF
Le code écrit en anglais structuré ressemble plus à l'anglais parlé au jour le jour. Il ne peut pas être implémenté directement en tant que code de logiciel. L'anglais structuré est indépendant du langage de programmation.
Pseudo-code
Le pseudo code est écrit plus près du langage de programmation. Il peut être considéré comme un langage de programmation augmenté, plein de commentaires et de descriptions.
Le pseudo-code évite la déclaration de variables mais ils sont écrits en utilisant des constructions réelles de langage de programmation, comme C, Fortran, Pascal etc.
Le pseudo-code contient plus de détails de programmation que l'anglais structuré. Il fournit une méthode pour exécuter la tâche, comme si un ordinateur exécutait le code.
Exemple
Programme pour imprimer Fibonacci jusqu'à n nombres.
void function Fibonacci
Get value of n;
Set value of a to 1;
Set value of b to 1;
Initialize I to 0
for (i=0; i< n; i++)
{
if a greater than b
{
Increase b by a;
Print b;
}
else if b greater than a
{
increase a by b;
print a;
}
}
Tables de décision
Un tableau de décision représente les conditions et les actions respectives à entreprendre pour y remédier, dans un format tabulaire structuré.
C'est un outil puissant pour déboguer et éviter les erreurs. Il permet de regrouper des informations similaires dans un seul tableau, puis en combinant des tableaux, il permet une prise de décision facile et pratique.
Créer une table de décision
Pour créer la table de décision, le développeur doit suivre quatre étapes de base:
- Identifier toutes les conditions possibles à traiter
- Déterminer les actions pour toutes les conditions identifiées
- Créer le maximum de règles possibles
- Définir une action pour chaque règle
Les tables de décision doivent être vérifiées par les utilisateurs finaux et peuvent être simplifiées récemment en éliminant les règles et actions en double.
Exemple
Prenons un exemple simple de problème quotidien avec notre connectivité Internet. Nous commençons par identifier tous les problèmes pouvant survenir lors du démarrage d'Internet et leurs solutions possibles respectives.
Nous listons tous les problèmes possibles sous les conditions de la colonne et les actions potentielles sous la colonne Actions.
Conditions / Actions | Règles | ||||||||
---|---|---|---|---|---|---|---|---|---|
Conditions | Spectacles connectés | N | N | N | N | Oui | Oui | Oui | Oui |
Ping fonctionne | N | N | Oui | Oui | N | N | Oui | Oui | |
Ouvre le site Web | Oui | N | Oui | N | Oui | N | Oui | N | |
Actions | Vérifiez le câble réseau | X | |||||||
Vérifiez le routeur Internet | X | X | X | X | |||||
Redémarrez le navigateur Web | X | ||||||||
Contacter le fournisseur de services | X | X | X | X | X | X | |||
Ne fais aucune action |
Modèle entité-relation
Le modèle Entité-Relation est un type de modèle de base de données basé sur la notion d'entités du monde réel et la relation entre elles. Nous pouvons mapper un scénario du monde réel sur un modèle de base de données ER. ER Model crée un ensemble d'entités avec leurs attributs, un ensemble de contraintes et une relation entre elles.
Le modèle ER est le mieux utilisé pour la conception conceptuelle de la base de données. Le modèle ER peut être représenté comme suit:
Entity - Une entité dans ER Model est un être du monde réel, qui a des propriétés appelées attributes. Chaque attribut est défini par son ensemble de valeurs correspondant, appelédomain.
Par exemple, considérons une base de données scolaire. Ici, un étudiant est une entité. L'élève a divers attributs comme le nom, l'identifiant, l'âge et la classe, etc.
Relationship - L'association logique entre les entités est appelée relationship. Les relations sont mappées avec les entités de différentes manières. Les cardinalités de mappage définissent le nombre d'associations entre deux entités.
Cartographie des cardinalités:
- Un par un
- un à plusieurs
- plusieurs à un
- plusieurs à plusieurs
Dictionnaire de données
Le dictionnaire de données est la collecte centralisée d'informations sur les données. Il stocke la signification et l'origine des données, sa relation avec d'autres données, le format des données à utiliser, etc. Le dictionnaire de données a des définitions rigoureuses de tous les noms afin de faciliter les concepteurs d'utilisateurs et de logiciels.
Le dictionnaire de données est souvent référencé en tant que référentiel de méta-données (données sur les données). Il est créé avec le modèle DFD (Data Flow Diagram) du logiciel et devrait être mis à jour chaque fois que DFD est modifié ou mis à jour.
Exigence du dictionnaire de données
Les données sont référencées via un dictionnaire de données lors de la conception et de la mise en œuvre du logiciel. Le dictionnaire de données supprime toute possibilité d'ambiguïté. Cela permet de synchroniser le travail des programmeurs et des concepteurs tout en utilisant la même référence d'objet partout dans le programme.
Le dictionnaire de données fournit un moyen de documentation pour le système de base de données complet en un seul endroit. La validation de DFD est effectuée à l'aide d'un dictionnaire de données.
Contenu
Le dictionnaire de données doit contenir des informations sur les éléments suivants
- Flux de données
- Structure de données
- Éléments de données
- Magasins de données
- Traitement de l'information
Le flux de données est décrit au moyen de DFD comme étudié précédemment et représenté sous forme algébrique comme décrit.
= | Composé de |
---|---|
{} | Répétition |
() | Optionnel |
+ | Et |
[/] | Ou |
Exemple
Adresse = No de la maison + (rue / région) + ville + état
ID du cours = numéro du cours + nom du cours + niveau du cours + notes du cours
Éléments de données
Les éléments de données se composent du nom et des descriptions des données et des éléments de contrôle, des magasins de données internes ou externes, etc. avec les détails suivants:
- Nom principal
- Nom secondaire (alias)
- Cas d'utilisation (comment et où utiliser)
- Description du contenu (notation, etc.)
- Informations complémentaires (valeurs prédéfinies, contraintes, etc.)
Magasin de données
Il stocke les informations à partir desquelles les données entrent dans le système et existent hors du système. Le magasin de données peut inclure -
- Files
- Interne au logiciel.
- Externe au logiciel mais sur la même machine.
- Externe au logiciel et au système, situé sur une machine différente.
- Tables
- Convention de dénomination
- Propriété d'indexation
Traitement de l'information
Il existe deux types de traitement des données:
- Logical: Comme l'utilisateur le voit
- Physical: Tel que le logiciel le voit
La conception logicielle est un processus permettant de conceptualiser les exigences logicielles en implémentation logicielle. La conception de logiciels prend les exigences des utilisateurs comme des défis et tente de trouver une solution optimale. Pendant la conceptualisation du logiciel, un plan est élaboré pour trouver la meilleure conception possible pour mettre en œuvre la solution prévue.
Il existe plusieurs variantes de conception de logiciels. Étudions-les brièvement:
Conception structurée
La conception structurée est une conceptualisation du problème en plusieurs éléments de solution bien organisés. Il s'agit essentiellement de la conception de la solution. L'avantage de la conception structurée est qu'elle permet de mieux comprendre comment le problème est résolu. La conception structurée permet également au concepteur de se concentrer plus précisément sur le problème.
La conception structurée est principalement basée sur la stratégie «diviser pour conquérir» où un problème est divisé en plusieurs petits problèmes et chaque petit problème est résolu individuellement jusqu'à ce que le problème soit résolu dans son ensemble.
Les petits problèmes sont résolus au moyen de modules de solution. La conception structurée met l'accent sur le fait que ces modules soient bien organisés afin de parvenir à une solution précise.
Ces modules sont organisés en hiérarchie. Ils communiquent entre eux. Une bonne conception structurée suit toujours certaines règles de communication entre plusieurs modules, à savoir -
Cohesion - regroupement de tous les éléments fonctionnellement liés.
Coupling - communication entre différents modules.
Une bonne conception structurée a une cohésion élevée et de faibles agencements de couplage.
Conception orientée fonction
Dans la conception orientée fonction, le système est composé de nombreux sous-systèmes plus petits appelés fonctions. Ces fonctions sont capables d'exécuter des tâches importantes dans le système. Le système est considéré comme une vue de dessus de toutes les fonctions.
La conception orientée fonction hérite de certaines propriétés de la conception structurée où la méthodologie de division et de conquête est utilisée.
Ce mécanisme de conception divise l'ensemble du système en fonctions plus petites, ce qui fournit des moyens d'abstraction en dissimulant les informations et leur fonctionnement. Ces modules fonctionnels peuvent partager des informations entre eux au moyen d'informations passant et utilisant des informations disponibles globalement.
Une autre caractéristique des fonctions est que lorsqu'un programme appelle une fonction, la fonction change l'état du programme, ce qui n'est parfois pas acceptable par d'autres modules. La conception orientée fonction fonctionne bien là où l'état du système n'a pas d'importance et le programme / les fonctions fonctionnent sur l'entrée plutôt que sur un état.
Procédé de design
- L'ensemble du système est considéré comme la manière dont les données circulent dans le système au moyen d'un diagramme de flux de données.
- DFD décrit comment les fonctions modifient les données et l'état de l'ensemble du système.
- L'ensemble du système est logiquement décomposé en unités plus petites appelées fonctions sur la base de leur fonctionnement dans le système.
- Chaque fonction est ensuite décrite dans son ensemble.
Conception orientée objet
La conception orientée objet fonctionne autour des entités et de leurs caractéristiques au lieu des fonctions impliquées dans le système logiciel. Cette stratégie de conception se concentre sur les entités et ses caractéristiques. Tout le concept de solution logicielle tourne autour des entités engagées.
Voyons les concepts importants de la conception orientée objet:
- Objects - Toutes les entités impliquées dans la conception de la solution sont appelées objets. Par exemple, la personne, les banques, l'entreprise et les clients sont traités comme des objets. Chaque entité a des attributs qui lui sont associés et a des méthodes à exécuter sur les attributs.
Classes - Une classe est une description généralisée d'un objet. Un objet est une instance d'une classe. La classe définit tous les attributs qu'un objet peut avoir et les méthodes qui définissent la fonctionnalité de l'objet.
Dans la conception de la solution, les attributs sont stockés sous forme de variables et les fonctionnalités sont définies au moyen de méthodes ou de procédures.
- Encapsulation - Dans OOD, les attributs (variables de données) et les méthodes (opération sur les données) sont regroupés ensemble est appelé encapsulation. L'encapsulation regroupe non seulement les informations importantes d'un objet, mais restreint également l'accès aux données et aux méthodes du monde extérieur. C'est ce qu'on appelle la dissimulation d'informations.
- Inheritance - OOD permet à des classes similaires de s'empiler de manière hiérarchique, les classes inférieures ou les sous-classes pouvant importer, implémenter et réutiliser des variables et des méthodes autorisées à partir de leurs super classes immédiates. Cette propriété d'OOD est connue sous le nom d'héritage. Cela facilite la définition d'une classe spécifique et la création de classes généralisées à partir de classes spécifiques.
- Polymorphism - Les langages OOD fournissent un mécanisme dans lequel les méthodes exécutant des tâches similaires mais dont les arguments varient peuvent se voir attribuer le même nom. C'est ce qu'on appelle le polymorphisme, qui permet à une seule interface d'effectuer des tâches pour différents types. Selon la façon dont la fonction est appelée, la partie respective du code est exécutée.
Procédé de design
Le processus de conception de logiciel peut être perçu comme une série d'étapes bien définies. Bien que cela varie en fonction de l'approche de conception (orientée fonction ou orientée objet, il peut cependant comporter les étapes suivantes:
- Une conception de solution est créée à partir des exigences ou du diagramme de séquence du système et / ou du système précédemment utilisé.
- Les objets sont identifiés et regroupés en classes au nom de la similitude des caractéristiques d'attribut.
- La hiérarchie des classes et la relation entre elles sont définies.
- Le cadre d'application est défini.
Approches de conception de logiciels
Voici deux approches génériques pour la conception de logiciels:
Conception descendante
Nous savons qu'un système est composé de plus d'un sous-système et qu'il contient un certain nombre de composants. En outre, ces sous-systèmes et composants peuvent avoir leur ensemble unique de sous-systèmes et de composants et créent une structure hiérarchique dans le système.
La conception descendante prend l'ensemble du système logiciel comme une seule entité, puis le décompose pour obtenir plus d'un sous-système ou composant en fonction de certaines caractéristiques. Chaque sous-système ou composant est ensuite traité comme un système et décomposé davantage. Ce processus continue à s'exécuter jusqu'à ce que le niveau le plus bas du système dans la hiérarchie descendante soit atteint.
La conception descendante commence par un modèle généralisé de système et continue de définir la partie la plus spécifique de celui-ci. Lorsque tous les composants sont composés, tout le système prend naissance.
La conception descendante est plus appropriée lorsque la solution logicielle doit être conçue à partir de zéro et que des détails spécifiques sont inconnus.
Conception ascendante
Le modèle de conception ascendant commence par les composants les plus spécifiques et de base. Il procède à la composition de composants de niveau supérieur en utilisant des composants de base ou de niveau inférieur. Il continue de créer des composants de niveau supérieur jusqu'à ce que le système souhaité ne soit pas développé comme un seul composant. Avec chaque niveau supérieur, la quantité d'abstraction est augmentée.
La stratégie ascendante est plus appropriée lorsqu'un système doit être créé à partir d'un système existant, où les primitives de base peuvent être utilisées dans le système plus récent.
Les approches descendantes et ascendantes ne sont pas réalisables individuellement. Au lieu de cela, une bonne combinaison des deux est utilisée.
L'interface utilisateur est la vue de l'application frontale avec laquelle l'utilisateur interagit pour utiliser le logiciel. L'utilisateur peut manipuler et contrôler le logiciel ainsi que le matériel au moyen de l'interface utilisateur. Aujourd'hui, l'interface utilisateur se trouve dans presque tous les endroits où la technologie numérique existe, directement depuis les ordinateurs, les téléphones portables, les voitures, les lecteurs de musique, les avions, les navires, etc.
L'interface utilisateur fait partie du logiciel et est conçue de telle manière qu'elle est censée fournir à l'utilisateur un aperçu du logiciel. L'interface utilisateur fournit une plate-forme fondamentale pour l'interaction homme-machine.
L'interface utilisateur peut être graphique, textuelle, audio-vidéo, en fonction de la combinaison matérielle et logicielle sous-jacente. L'interface utilisateur peut être matérielle ou logicielle ou une combinaison des deux.
Le logiciel devient plus populaire si son interface utilisateur est:
- Attractive
- Utilisation simple
- Réactif en peu de temps
- Clair pour comprendre
- Cohérent sur tous les écrans d'interfaçage
L'interface utilisateur est globalement divisée en deux catégories:
- Interface de ligne de commande
- Interface utilisateur graphique
Interface de ligne de commande (CLI)
La CLI a été un excellent outil d'interaction avec les ordinateurs jusqu'à ce que les moniteurs d'affichage vidéo apparaissent. CLI est le premier choix de nombreux utilisateurs techniques et programmeurs. CLI est l'interface minimale qu'un logiciel peut fournir à ses utilisateurs.
La CLI fournit une invite de commande, l'endroit où l'utilisateur tape la commande et alimente le système. L'utilisateur doit se souvenir de la syntaxe de la commande et de son utilisation. Les CLI antérieures n'étaient pas programmées pour gérer efficacement les erreurs utilisateur.
Une commande est une référence textuelle à un ensemble d'instructions, qui sont censées être exécutées par le système. Il existe des méthodes telles que les macros, les scripts qui facilitent l'utilisation par l'utilisateur.
CLI utilise moins de ressources informatiques par rapport à l'interface graphique.
Éléments CLI
Une interface de ligne de commande textuelle peut avoir les éléments suivants:
Command Prompt- C'est un notificateur basé sur du texte qui montre principalement le contexte dans lequel l'utilisateur travaille. Il est généré par le système logiciel.
Cursor- C'est une petite ligne horizontale ou une barre verticale de la hauteur de la ligne, pour représenter la position du caractère lors de la frappe. Le curseur se trouve principalement à l'état clignotant. Il se déplace lorsque l'utilisateur écrit ou supprime quelque chose.
Command- Une commande est une instruction exécutable. Il peut avoir un ou plusieurs paramètres. La sortie lors de l'exécution de la commande est affichée en ligne à l'écran. Lorsque la sortie est produite, l'invite de commande s'affiche sur la ligne suivante.
Interface utilisateur graphique
L'interface utilisateur graphique fournit à l'utilisateur des moyens graphiques d'interagir avec le système. L'interface graphique peut être une combinaison de matériel et de logiciel. À l'aide de l'interface graphique, l'utilisateur interprète le logiciel.
En règle générale, l'interface graphique consomme plus de ressources que celle de l'interface de ligne de commande. Avec les progrès de la technologie, les programmeurs et les concepteurs créent des conceptions GUI complexes qui fonctionnent avec plus d'efficacité, de précision et de vitesse.
Éléments de l'interface graphique
L'interface graphique fournit un ensemble de composants pour interagir avec le logiciel ou le matériel.
Chaque composant graphique fournit un moyen de travailler avec le système. Un système GUI comprend les éléments suivants tels que:
Window- Une zone où le contenu de l'application est affiché. Le contenu d'une fenêtre peut être affiché sous forme d'icônes ou de listes, si la fenêtre représente une structure de fichiers. Il est plus facile pour un utilisateur de naviguer dans le système de fichiers dans une fenêtre d'exploration. Windows peut être réduit, redimensionné ou agrandi à la taille de l'écran. Ils peuvent être déplacés n'importe où sur l'écran. Une fenêtre peut contenir une autre fenêtre de la même application, appelée fenêtre enfant.
Tabs - Si une application permet d'exécuter plusieurs instances d'elle-même, elles apparaissent à l'écran sous forme de fenêtres séparées. Tabbed Document Interfaceest venu ouvrir plusieurs documents dans la même fenêtre. Cette interface aide également à afficher le panneau de préférences dans l'application. Tous les navigateurs Web modernes utilisent cette fonctionnalité.
Menu- Menu est un tableau de commandes standard, regroupées et placées à un endroit visible (généralement en haut) dans la fenêtre de l'application. Le menu peut être programmé pour apparaître ou se cacher sur des clics de souris.
Icon- Une icône est une petite image représentant une application associée. Lorsque ces icônes sont cliquées ou double-cliquées, la fenêtre de l'application s'ouvre. L'icône affiche les applications et les programmes installés sur un système sous forme de petites images.
Cursor- Les périphériques interactifs tels que la souris, le pavé tactile, le stylet numérique sont représentés dans l'interface graphique sous forme de curseurs. Le curseur à l'écran suit les instructions du matériel presque en temps réel. Les curseurs sont également appelés pointeurs dans les systèmes GUI. Ils sont utilisés pour sélectionner des menus, des fenêtres et d'autres fonctionnalités de l'application.
Composants GUI spécifiques à l'application
Une interface graphique d'une application contient un ou plusieurs des éléments de l'interface graphique répertoriés:
Application Window - La plupart des fenêtres d'application utilisent les constructions fournies par les systèmes d'exploitation, mais beaucoup utilisent leurs propres fenêtres créées par le client pour contenir le contenu de l'application.
Dialogue Box - C'est une fenêtre enfant qui contient un message pour l'utilisateur et une demande d'action à entreprendre. Par exemple: l'application génère une boîte de dialogue pour obtenir la confirmation de l'utilisateur de supprimer un fichier.
Text-Box - Fournit une zone permettant à l'utilisateur de taper et de saisir des données textuelles.
Buttons - Ils imitent les boutons réels et sont utilisés pour soumettre des entrées au logiciel.
Radio-button- Affiche les options disponibles pour la sélection. Un seul peut être sélectionné parmi toutes les offres.
Check-box- Fonctions similaires à list-box. Lorsqu'une option est sélectionnée, la case est cochée. Plusieurs options représentées par des cases à cocher peuvent être sélectionnées.
List-box - Fournit la liste des éléments disponibles pour la sélection. Plus d'un élément peut être sélectionné.
Les autres composants graphiques impressionnants sont:
- Sliders
- Combo-box
- Data-grid
- La liste déroulante
Activités de conception d'interface utilisateur
Un certain nombre d'activités sont effectuées pour la conception de l'interface utilisateur. Le processus de conception et de mise en œuvre de l'interface graphique est similaire au SDLC. N'importe quel modèle peut être utilisé pour l'implémentation GUI parmi les modèles en cascade, itératif ou en spirale.
Un modèle utilisé pour la conception et le développement de l'interface graphique doit respecter ces étapes spécifiques à l'interface graphique.
GUI Requirement Gathering- Les concepteurs peuvent souhaiter avoir une liste de toutes les exigences fonctionnelles et non fonctionnelles de l'interface graphique. Cela peut être extrait de l'utilisateur et de sa solution logicielle existante.
User Analysis- Le concepteur étudie qui va utiliser l'interface graphique du logiciel. Le public cible est important car les détails de conception changent en fonction des connaissances et du niveau de compétence de l'utilisateur. Si l'utilisateur est techniquement averti, une interface graphique avancée et complexe peut être incorporée. Pour un utilisateur novice, plus d'informations sont incluses sur la procédure du logiciel.
Task Analysis- Les concepteurs doivent analyser quelle tâche doit être effectuée par la solution logicielle. Ici, dans GUI, peu importe comment cela sera fait. Les tâches peuvent être représentées de manière hiérarchique en prenant une tâche principale et en la divisant davantage en sous-tâches plus petites. Les tâches fournissent des objectifs pour la présentation de l'interface graphique. Le flux d'informations entre les sous-tâches détermine le flux du contenu de l'interface graphique dans le logiciel.
GUI Design & implementation- Les concepteurs après avoir eu des informations sur les exigences, les tâches et l'environnement utilisateur, conçoivent l'interface graphique et les implémentent dans le code et intègrent l'interface graphique avec un logiciel fonctionnel ou factice en arrière-plan. Il est ensuite auto-testé par les développeurs.
Testing- Les tests GUI peuvent être effectués de différentes manières. L'organisation peut avoir une inspection interne, l'implication directe des utilisateurs et la sortie de la version bêta sont peu d'entre eux. Les tests peuvent inclure la convivialité, la compatibilité, l'acceptation par l'utilisateur, etc.
Outils d'implémentation GUI
Il existe plusieurs outils disponibles à l'aide desquels les concepteurs peuvent créer une interface graphique complète en un clic de souris. Certains outils peuvent être intégrés dans l'environnement logiciel (IDE).
Les outils d'implémentation GUI fournissent une gamme puissante de contrôles GUI. Pour la personnalisation du logiciel, les concepteurs peuvent modifier le code en conséquence.
Il existe différents segments d'outils GUI en fonction de leur utilisation et de leur plate-forme différentes.
Exemple
Interface graphique mobile, interface graphique d'ordinateur, interface graphique à écran tactile, etc. Voici une liste de quelques outils utiles pour créer une interface graphique:
- FLUID
- AppInventor (Android)
- LucidChart
- Wavemaker
- Visual Studio
Règles d'or de l'interface utilisateur
Les règles suivantes sont mentionnées comme étant les règles d'or pour la conception de l'interface graphique, décrites par Shneiderman et Plaisant dans leur livre (Designing the User Interface).
Strive for consistency- Des séquences d'actions cohérentes devraient être requises dans des situations similaires. Une terminologie identique doit être utilisée dans les invites, les menus et les écrans d'aide. Des commandes cohérentes doivent être utilisées partout.
Enable frequent users to use short-cuts- La volonté de l'utilisateur de réduire le nombre d'interactions augmente avec la fréquence d'utilisation. Les abréviations, les touches de fonction, les commandes cachées et les macros sont très utiles à un utilisateur expérimenté.
Offer informative feedback- Pour chaque action de l'opérateur, il devrait y avoir un retour d'information du système. Pour les actions fréquentes et mineures, la réponse doit être modeste, tandis que pour les actions rares et majeures, la réponse doit être plus substantielle.
Design dialog to yield closure- Les séquences d'actions doivent être organisées en groupes avec un début, un milieu et une fin. Le retour d'information à la fin d'un groupe d'actions donne aux opérateurs la satisfaction de l'accomplissement, un sentiment de soulagement, le signal de laisser tomber les plans d'urgence et les options de leur esprit, et cela indique que la voie à suivre est claire pour se préparer au prochain. groupe d'actions.
Offer simple error handling- Autant que possible, concevez le système de manière à ce que l'utilisateur ne fasse pas d'erreur grave. Si une erreur est commise, le système doit être capable de la détecter et offrir des mécanismes simples et compréhensibles pour gérer l'erreur.
Permit easy reversal of actions- Cette fonction soulage l'anxiété, car l'utilisateur sait que les erreurs peuvent être annulées. Une inversion facile des actions encourage l'exploration d'options inconnues. Les unités de réversibilité peuvent être une action unique, une saisie de données ou un groupe complet d'actions.
Support internal locus of control- Les opérateurs expérimentés souhaitent vivement avoir le sentiment qu'ils sont en charge du système et que le système répond à leurs actions. Concevez le système pour faire des utilisateurs les initiateurs des actions plutôt que les répondeurs.
Reduce short-term memory load - La limitation du traitement de l'information humaine dans la mémoire à court terme nécessite que les affichages restent simples, que les affichages de plusieurs pages soient consolidés, que la fréquence de mouvement des fenêtres soit réduite et qu'un temps d'apprentissage suffisant soit alloué pour les codes, les mnémoniques et les séquences d'actions.
Le terme complexité désigne l'état des événements ou des choses, qui ont de multiples liens interconnectés et des structures très complexes. En programmation logicielle, au fur et à mesure que la conception du logiciel est réalisée, le nombre d'éléments et leurs interconnexions deviennent progressivement énormes, ce qui devient trop difficile à comprendre à la fois.
La complexité de la conception logicielle est difficile à évaluer sans utiliser des mesures et des mesures de complexité. Voyons trois mesures importantes de la complexité des logiciels.
Mesures de complexité de Halstead
En 1977, M. Maurice Howard Halstead a introduit des mesures pour mesurer la complexité des logiciels. Les métriques de Halstead dépendent de la mise en œuvre réelle du programme et de ses mesures, qui sont calculées directement à partir des opérateurs et des opérandes du code source, de manière statique. Il permet d'évaluer le temps de test, le vocabulaire, la taille, la difficulté, les erreurs et les efforts pour le code source C / C ++ / Java.
Selon Halstead, «un programme informatique est une implémentation d'un algorithme considéré comme une collection de jetons qui peuvent être classés en tant qu'opérateurs ou opérandes». Les métriques Halstead conçoivent un programme comme une séquence d'opérateurs et de leurs opérandes associés.
Il définit différents indicateurs pour vérifier la complexité du module.
Paramètre | Sens |
---|---|
n1 | Nombre d'opérateurs uniques |
n2 | Nombre d'opérandes uniques |
N1 | Nombre d'occurrences totales d'opérateurs |
N2 | Nombre d'occurrences totales d'opérandes |
Lorsque nous sélectionnons le fichier source pour afficher ses détails de complexité dans Metric Viewer, le résultat suivant s'affiche dans Metric Report:
Métrique | Sens | Représentation mathématique |
---|---|---|
n | Vocabulaire | n1 + n2 |
N | Taille | N1 + N2 |
V | Le volume | Longueur * Vocabulaire Log2 |
ré | Difficulté | (n1 / 2) * (N1 / n2) |
E | Efforts | Difficulté * Volume |
B | les erreurs | Volume / 3000 |
T | Temps de test | Temps = Efforts / S, où S = 18 secondes. |
Mesures de complexité cyclomatique
Chaque programme comprend des instructions à exécuter pour effectuer une tâche et d'autres instructions de prise de décision qui décident quelles instructions doivent être exécutées. Ces concepts de prise de décision modifient le déroulement du programme.
Si nous comparons deux programmes de même taille, celui avec le plus d'énoncés décisionnels sera plus complexe car le contrôle du programme saute fréquemment.
McCabe, en 1976, a proposé la mesure de complexité cyclomatique pour quantifier la complexité d'un logiciel donné. Il s'agit d'un modèle basé sur un graphique basé sur des constructions de prise de décision de programme telles que les instructions if-else, do-while, repeat-until, switch-case et goto.
Processus pour créer un graphique de contrôle de flux:
- Découpez le programme en blocs plus petits, délimités par des constructions décisionnelles.
- Créez des nœuds représentant chacun de ces nœuds.
- Connectez les nœuds comme suit:
Si le contrôle peut passer du bloc i au bloc j
Dessinez un arc
Du nœud de sortie au nœud d'entrée
Dessinez un arc.
Pour calculer la complexité cyclomatique d'un module de programme, nous utilisons la formule -
V(G) = e – n + 2
Where
e is total number of edges
n is total number of nodes
La complexité cyclomatique du module ci-dessus est
e = 10
n = 8
Cyclomatic Complexity = 10 - 8 + 2
= 4
Selon P. Jorgensen, la complexité cyclomatique d'un module ne doit pas dépasser 10.
Point de fonction
Il est largement utilisé pour mesurer la taille des logiciels. Function Point se concentre sur les fonctionnalités fournies par le système. Les caractéristiques et fonctionnalités du système sont utilisées pour mesurer la complexité du logiciel.
Le point de fonction compte sur cinq paramètres, nommés comme entrée externe, sortie externe, fichiers internes logiques, fichiers d'interface externe et interrogation externe. Pour tenir compte de la complexité du logiciel, chaque paramètre est en outre catégorisé comme simple, moyen ou complexe.
Voyons les paramètres du point de fonction:
Entrée externe
Chaque entrée unique du système, de l'extérieur, est considérée comme une entrée externe. L'unicité de l'entrée est mesurée, car deux entrées ne doivent pas avoir les mêmes formats. Ces entrées peuvent être des données ou des paramètres de contrôle.
Simple - si le nombre d'entrées est faible et affecte moins de fichiers internes
Complex - si le nombre d'entrées est élevé et affecte plus de fichiers internes
Average - entre simple et complexe.
Sortie externe
Tous les types de sortie fournis par le système sont comptés dans cette catégorie. La sortie est considérée comme unique si son format de sortie et / ou son traitement sont uniques.
Simple - si le nombre de sorties est faible
Complex - si le nombre de sorties est élevé
Average - entre simple et complexe.
Fichiers internes logiques
Chaque système logiciel maintient des fichiers internes afin de maintenir ses informations fonctionnelles et de fonctionner correctement. Ces fichiers contiennent des données logiques du système. Ces données logiques peuvent contenir à la fois des données fonctionnelles et des données de contrôle.
Simple - si le nombre de types d'enregistrement est faible
Complex - si le nombre de types d'enregistrement est élevé
Average - entre simple et complexe.
Fichiers d'interface externe
Le système logiciel peut avoir besoin de partager ses fichiers avec un logiciel externe ou il peut avoir besoin de transmettre le fichier pour traitement ou comme paramètre à une fonction. Tous ces fichiers sont comptés comme des fichiers d'interface externes.
Simple - si le nombre de types d'enregistrement dans le fichier partagé est faible
Complex - si le nombre de types d'enregistrement dans le fichier partagé est élevé
Average - entre simple et complexe.
Enquête externe
Une demande est une combinaison d'entrée et de sortie, où l'utilisateur envoie des données à interroger comme entrée et le système répond à l'utilisateur avec la sortie de la demande traitée. La complexité d'une requête va au-delà des entrées externes et des sorties externes. La requête est dite unique si son entrée et sa sortie sont uniques en termes de format et de données.
Simple - si la requête nécessite un faible traitement et produit une petite quantité de données de sortie
Complex - si la requête nécessite un processus élevé et produit une grande quantité de données de sortie
Average - entre simple et complexe.
Chacun de ces paramètres du système reçoit une pondération en fonction de sa classe et de sa complexité. Le tableau ci-dessous mentionne la pondération donnée à chaque paramètre:
Paramètre | Facile | Moyenne | Complexe |
---|---|---|---|
Contributions | 3 | 4 | 6 |
Les sorties | 4 | 5 | sept |
Enquête | 3 | 4 | 6 |
Des dossiers | sept | dix | 15 |
Interfaces | 5 | sept | dix |
Le tableau ci-dessus donne des points de fonction bruts. Ces points de fonction sont ajustés en fonction de la complexité de l'environnement. Le système est décrit en utilisant quatorze caractéristiques différentes:
- Données de communication
- Traitement distribué
- Objectifs de performance
- Charge de configuration d'opération
- Taux de transaction
- Saisie de données en ligne,
- Efficacité de l'utilisateur final
- Mise à jour en ligne
- Logique de traitement complexe
- Re-usability
- Facilité d'installation
- Facilité opérationnelle
- Sites multiples
- Désir de faciliter les changements
Ces facteurs caractéristiques sont ensuite notés de 0 à 5, comme indiqué ci-dessous:
- Aucune influence
- Incidental
- Moderate
- Average
- Significant
- Essential
Toutes les notes sont ensuite résumées par N. La valeur de N varie de 0 à 70 (14 types de caractéristiques x 5 types de notes). Il est utilisé pour calculer les facteurs d'ajustement de la complexité (CAF) à l'aide des formules suivantes:
CAF = 0.65 + 0.01N
Ensuite,
Delivered Function Points (FP)= CAF x Raw FP
Ce FP peut ensuite être utilisé dans diverses métriques, telles que:
Cost = $ / FP
Quality = Erreurs / FP
Productivity = PF / personne-mois
Dans ce chapitre, nous étudierons les méthodes de programmation, la documentation et les défis de la mise en œuvre logicielle.
Programmation structurée
Dans le processus de codage, les lignes de code continuent à se multiplier, ainsi, la taille du logiciel augmente. Peu à peu, il devient pratiquement impossible de se souvenir du déroulement du programme. Si l'on oublie comment le logiciel et ses programmes, fichiers, procédures sous-jacents sont construits, il devient alors très difficile de partager, déboguer et modifier le programme. La solution à cela est la programmation structurée. Il encourage le développeur à utiliser des sous-programmes et des boucles au lieu d'utiliser de simples sauts dans le code, apportant ainsi de la clarté dans le code et améliorant son efficacité La programmation structurée aide également le programmeur à réduire le temps de codage et à organiser le code correctement.
La programmation structurée indique comment le programme doit être codé. La programmation structurée utilise trois concepts principaux:
Top-down analysis- Un logiciel est toujours fait pour effectuer un travail rationnel. Ce travail rationnel est connu sous le nom de problème dans le langage logiciel. Il est donc très important que nous comprenions comment résoudre le problème. Dans le cadre d'une analyse descendante, le problème est décomposé en petits morceaux où chacun a une certaine importance. Chaque problème est résolu individuellement et les étapes sont clairement énoncées sur la façon de résoudre le problème.
Modular Programming- Lors de la programmation, le code est décomposé en un plus petit groupe d'instructions. Ces groupes sont appelés modules, sous-programmes ou sous-programmes. Programmation modulaire basée sur la compréhension de l'analyse descendante. Il décourage les sauts en utilisant des instructions «goto» dans le programme, ce qui rend souvent le déroulement du programme non traçable. Les sauts sont interdits et le format modulaire est encouragé dans la programmation structurée.
Structured Coding - En référence à l'analyse descendante, le codage structuré subdivise les modules en unités de code encore plus petites dans l'ordre de leur exécution. La programmation structurée utilise une structure de contrôle, qui contrôle le flux du programme, tandis que le codage structuré utilise une structure de contrôle pour organiser ses instructions dans des modèles définissables.
Programmation fonctionnelle
La programmation fonctionnelle est un style de langage de programmation, qui utilise les concepts de fonctions mathématiques. Une fonction en mathématiques doit toujours produire le même résultat en recevant le même argument. Dans les langages procéduraux, le flux du programme passe par des procédures, c'est-à-dire que le contrôle du programme est transféré à la procédure appelée. Pendant que le flux de contrôle passe d'une procédure à une autre, le programme change d'état.
Dans la programmation procédurale, il est possible pour une procédure de produire des résultats différents lorsqu'elle est appelée avec le même argument, car le programme lui-même peut être dans un état différent lors de son appel. C'est une propriété ainsi qu'un inconvénient de la programmation procédurale, dans laquelle la séquence ou le moment de l'exécution de la procédure devient important.
La programmation fonctionnelle fournit des moyens de calcul sous forme de fonctions mathématiques, qui produisent des résultats quel que soit l'état du programme. Cela permet de prédire le comportement du programme.
La programmation fonctionnelle utilise les concepts suivants:
First class and High-order functions - Ces fonctions ont la capacité d'accepter une autre fonction comme argument ou elles renvoient d'autres fonctions comme résultats.
Pure functions - Ces fonctions n'incluent pas les mises à jour destructives, c'est-à-dire qu'elles n'affectent aucune E / S ou mémoire et si elles ne sont pas utilisées, elles peuvent être facilement supprimées sans gêner le reste du programme.
Recursion- La récursivité est une technique de programmation où une fonction s'appelle elle-même et répète le code de programme qu'elle contient à moins qu'une condition prédéfinie ne corresponde. La récursivité est le moyen de créer des boucles dans la programmation fonctionnelle.
Strict evaluation- C'est une méthode d'évaluation de l'expression passée à une fonction en tant qu'argument. La programmation fonctionnelle a deux types de méthodes d'évaluation, stricte (impatiente) ou non stricte (paresseuse). Une évaluation stricte évalue toujours l'expression avant d'appeler la fonction. Une évaluation non stricte n'évalue pas l'expression à moins qu'elle ne soit nécessaire.
λ-calculus- La plupart des langages de programmation fonctionnels utilisent le λ-calcul comme systèmes de types. Les expressions λ sont exécutées en les évaluant au fur et à mesure qu'elles se produisent.
Common Lisp, Scala, Haskell, Erlang et F # sont quelques exemples de langages de programmation fonctionnels.
Style de programmation
Le style de programmation est un ensemble de règles de codage suivies par tous les programmeurs pour écrire le code. Lorsque plusieurs programmeurs travaillent sur le même projet logiciel, ils doivent fréquemment travailler avec le code du programme écrit par un autre développeur. Cela devient fastidieux ou parfois impossible, si tous les développeurs ne suivent pas un style de programmation standard pour coder le programme.
Un style de programmation approprié comprend l'utilisation de noms de fonctions et de variables pertinents pour la tâche prévue, l'utilisation d'une indentation bien placée, le code de commentaire pour la commodité du lecteur et la présentation générale du code. Cela rend le code du programme lisible et compréhensible par tous, ce qui facilite le débogage et la résolution des erreurs. En outre, un style de codage approprié facilite la documentation et la mise à jour.
Directives de codage
La pratique du style de codage varie selon les organisations, les systèmes d'exploitation et la langue de codage elle-même.
Les éléments de codage suivants peuvent être définis selon les directives de codage d'une organisation:
Naming conventions - Cette section définit comment nommer les fonctions, les variables, les constantes et les variables globales.
Indenting - Il s'agit de l'espace laissé au début de la ligne, généralement de 2 à 8 espaces ou une seule tabulation.
Whitespace - Il est généralement omis en fin de ligne.
Operators- Définit les règles d'écriture des opérateurs mathématiques, d'assignation et logiques. Par exemple, l'opérateur d'affectation '=' doit avoir un espace avant et après lui, comme dans «x = 2».
Control Structures - Les règles d'écriture if-then-else, case-switch, while-Until et pour les instructions de flux de contrôle uniquement et de manière imbriquée.
Line length and wrapping- Définit le nombre de caractères qui doivent être présents sur une ligne, la plupart du temps une ligne est de 80 caractères. L'emballage définit comment une ligne doit être enveloppée, si elle est trop longue.
Functions - Ceci définit comment les fonctions doivent être déclarées et appelées, avec et sans paramètres.
Variables - Ceci mentionne comment les variables de différents types de données sont déclarées et définies.
Comments- C'est l'un des composants de codage importants, car les commentaires inclus dans le code décrivent ce que fait réellement le code et toutes les autres descriptions associées. Cette section permet également de créer des documentations d'aide pour d'autres développeurs.
Documentation du logiciel
La documentation du logiciel est une partie importante du processus logiciel. Un document bien écrit fournit un excellent outil et un moyen de référentiel d'informations nécessaires pour connaître les processus logiciels. La documentation du logiciel fournit également des informations sur l'utilisation du produit.
Une documentation bien tenue doit comprendre les documents suivants:
Requirement documentation - Cette documentation fonctionne comme un outil clé pour le concepteur de logiciel, le développeur et l'équipe de test pour mener à bien leurs tâches respectives. Ce document contient toute la description fonctionnelle, non fonctionnelle et comportementale du logiciel prévu.
La source de ce document peut être des données préalablement stockées sur le logiciel, des logiciels déjà en cours d'exécution chez le client, des entretiens avec le client, des questionnaires et des recherches. Généralement, il est stocké sous forme de feuille de calcul ou de document de traitement de texte avec l'équipe de gestion de logiciels haut de gamme.
Cette documentation sert de base au logiciel à développer et est principalement utilisée dans les phases de vérification et de validation. La plupart des cas de test sont construits directement à partir de la documentation des exigences.
Software Design documentation - Ces documentations contiennent toutes les informations nécessaires, qui sont nécessaires pour construire le logiciel. Il contient:(a) Architecture logicielle de haut niveau, (b) Détails de conception du logiciel, (c) Diagrammes de flux de données, (d) Conception de base de données
Ces documents fonctionnent comme un référentiel pour que les développeurs implémentent le logiciel. Bien que ces documents ne donnent pas de détails sur la façon de coder le programme, ils donnent toutes les informations nécessaires pour le codage et la mise en œuvre.
Technical documentation- Ces documentations sont maintenues par les développeurs et les codeurs actuels. Ces documents, dans leur ensemble, représentent des informations sur le code. Lors de l'écriture du code, les programmeurs mentionnent également l'objectif du code, qui l'a écrit, où sera-t-il requis, ce qu'il fait et comment il le fait, quelles autres ressources le code utilise, etc.
La documentation technique augmente la compréhension entre les différents programmeurs travaillant sur le même code. Il améliore la capacité de réutilisation du code. Cela rend le débogage facile et traçable.
Il existe divers outils automatisés disponibles et certains sont livrés avec le langage de programmation lui-même. Par exemple, java est un outil JavaDoc pour générer la documentation technique du code.
User documentation- Cette documentation est différente de toutes les explications ci-dessus. Toutes les documentations précédentes sont maintenues pour fournir des informations sur le logiciel et son processus de développement. Mais la documentation utilisateur explique comment le produit logiciel doit fonctionner et comment il doit être utilisé pour obtenir les résultats souhaités.
Ces documentations peuvent inclure des procédures d'installation de logiciels, des guides pratiques, des guides de l'utilisateur, une méthode de désinstallation et des références spéciales pour obtenir plus d'informations comme la mise à jour de la licence, etc.
Défis de mise en œuvre logicielle
L'équipe de développement doit faire face à certains défis lors de la mise en œuvre du logiciel. Certains d'entre eux sont mentionnés ci-dessous:
Code-reuse- Les interfaces de programmation des langages actuels sont très sophistiquées et sont équipées d'énormes fonctions de bibliothèque. Pourtant, pour réduire le coût du produit final, la direction de l'organisation préfère réutiliser le code, qui a été créé plus tôt pour certains autres logiciels. Les programmeurs rencontrent d'énormes problèmes pour vérifier la compatibilité et décider de la quantité de code à réutiliser.
Version Management- Chaque fois qu'un nouveau logiciel est fourni au client, les développeurs doivent maintenir la documentation relative à la version et à la configuration. Cette documentation doit être très précise et disponible à temps.
Target-Host- Le logiciel, qui est en cours de développement dans l'organisation, doit être conçu pour les machines hôtes du côté des clients. Mais parfois, il est impossible de concevoir un logiciel qui fonctionne sur les machines cibles.
Le test logiciel est une évaluation du logiciel par rapport aux exigences recueillies auprès des utilisateurs et des spécifications du système. Les tests sont effectués au niveau de la phase dans le cycle de vie du développement logiciel ou au niveau du module dans le code du programme. Les tests logiciels comprennent la validation et la vérification.
Validation du logiciel
La validation est un processus consistant à examiner si le logiciel répond ou non aux exigences de l'utilisateur. Il est réalisé à la fin du SDLC. Si le logiciel correspond aux exigences pour lesquelles il a été réalisé, il est validé.
- La validation garantit que le produit en cours de développement est conforme aux exigences de l'utilisateur.
- La validation répond à la question - "Développons-nous le produit qui répond à tout ce dont l'utilisateur a besoin de ce logiciel?".
- La validation met l'accent sur les exigences des utilisateurs.
Vérification du logiciel
La vérification est le processus de confirmation si le logiciel répond aux exigences de l'entreprise et est développé conformément aux spécifications et méthodologies appropriées.
- La vérification garantit que le produit en cours de développement est conforme aux spécifications de conception.
- La vérification répond à la question: "Développons-nous ce produit en suivant fermement toutes les spécifications de conception?"
- Les vérifications se concentrent sur la conception et les spécifications du système.
Les cibles du test sont -
Errors- Ce sont de réelles erreurs de codage commises par les développeurs. De plus, il y a une différence dans la sortie du logiciel et la sortie souhaitée, est considérée comme une erreur.
Fault- Lorsqu'une erreur existe, un défaut se produit. Une erreur, également connue sous le nom de bogue, est le résultat d'une erreur qui peut entraîner une défaillance du système.
Failure - on dit que l'échec est l'incapacité du système à exécuter la tâche souhaitée. Une panne se produit lorsqu'une panne existe dans le système.
Test manuel vs test automatisé
Les tests peuvent être effectués manuellement ou à l'aide d'un outil de test automatisé:
Manual- Ce test est effectué sans l'aide d'outils de test automatisés. Le testeur logiciel prépare les cas de test pour différentes sections et niveaux du code, exécute les tests et rapporte le résultat au gestionnaire.
Les tests manuels demandent du temps et des ressources. Le testeur doit confirmer si les bons cas de test sont utilisés ou non. La majeure partie des tests implique des tests manuels.
AutomatedCe test est une procédure de test réalisée à l'aide d'outils de test automatisés. Les limites des tests manuels peuvent être surmontées à l'aide d'outils de test automatisés.
Un test doit vérifier si une page Web peut être ouverte dans Internet Explorer. Cela peut être facilement réalisé avec des tests manuels. Mais pour vérifier si le serveur Web peut supporter 1 million d'utilisateurs, il est tout à fait impossible de tester manuellement.
Il existe des outils logiciels et matériels qui aident les testeurs à effectuer des tests de charge, des tests de résistance et des tests de régression.
Approches de test
Les tests peuvent être menés selon deux approches -
- Test de fonctionnalité
- Test de mise en œuvre
Lorsque la fonctionnalité est testée sans prendre en compte l'implémentation réelle, on parle de test de boîte noire. L'autre côté est connu sous le nom de test de boîte blanche où non seulement la fonctionnalité est testée, mais la façon dont elle est mise en œuvre est également analysée.
Les tests exhaustifs sont la meilleure méthode souhaitée pour un test parfait. Chaque valeur possible dans la plage des valeurs d'entrée et de sortie est testée. Il n'est pas possible de tester chaque valeur dans un scénario du monde réel si la plage de valeurs est large.
Test en boîte noire
Il est effectué pour tester la fonctionnalité du programme. Il est également appelé test «comportemental». Le testeur dans ce cas, a un ensemble de valeurs d'entrée et des résultats souhaités respectifs. En fournissant une entrée, si la sortie correspond aux résultats souhaités, le programme est testé «ok», et problématique dans le cas contraire.
Dans cette méthode de test, la conception et la structure du code ne sont pas connues du testeur, et les ingénieurs de test et les utilisateurs finaux effectuent ce test sur le logiciel.
Techniques de test en boîte noire:
Equivalence class- L'entrée est divisée en classes similaires. Si un élément d'une classe réussit le test, on suppose que toute la classe est passée.
Boundary values- L'entrée est divisée en valeurs finales supérieures et inférieures. Si ces valeurs réussissent le test, on suppose que toutes les valeurs intermédiaires peuvent également réussir.
Cause-effect graphing- Dans les deux méthodes précédentes, une seule valeur d'entrée à la fois est testée. Cause (entrée) - L'effet (sortie) est une technique de test où les combinaisons de valeurs d'entrée sont testées de manière systématique.
Pair-wise Testing- Le comportement du logiciel dépend de plusieurs paramètres. Dans les tests par paires, les multiples paramètres sont testés par paires pour leurs différentes valeurs.
State-based testing- Le système change d'état lors de la fourniture de l'entrée. Ces systèmes sont testés en fonction de leurs états et de leurs entrées.
Test en boîte blanche
Il est effectué pour tester le programme et sa mise en œuvre, afin d'améliorer l'efficacité ou la structure du code. Il est également connu sous le nom de test «structurel».
Dans cette méthode de test, la conception et la structure du code sont connues du testeur. Les programmeurs du code effectuent ce test sur le code.
Voici quelques techniques de test en boîte blanche:
Control-flow testing- Le but du test de flux de contrôle est de mettre en place des cas de test qui couvrent toutes les déclarations et conditions de branchement. Les conditions de branchement sont testées pour être à la fois vraies et fausses, de sorte que toutes les déclarations puissent être couvertes.
Data-flow testing- Cette technique de test met l'accent sur toutes les variables de données incluses dans le programme. Il teste où les variables ont été déclarées et définies et où elles ont été utilisées ou modifiées.
Niveaux de test
Le test lui-même peut être défini à différents niveaux de SDLC. Le processus de test est parallèle au développement logiciel. Avant de passer à l'étape suivante, une étape est testée, validée et vérifiée.
Les tests séparément sont effectués uniquement pour s'assurer qu'il n'y a plus de bogues ou de problèmes cachés dans le logiciel. Le logiciel est testé à différents niveaux -
Test unitaire
Pendant le codage, le programmeur effectue des tests sur cette unité de programme pour savoir si elle est sans erreur. Les tests sont effectués selon une approche de test en boîte blanche. Les tests unitaires aident les développeurs à décider que les unités individuelles du programme fonctionnent selon les exigences et sont sans erreur.
Test d'intégration
Même si les unités de logiciel fonctionnent correctement individuellement, il est nécessaire de savoir si les unités, si elles sont intégrées ensemble, fonctionneraient également sans erreurs. Par exemple, la transmission d'arguments et la mise à jour des données, etc.
Test du système
Le logiciel est compilé en tant que produit, puis il est testé dans son ensemble. Cela peut être accompli en utilisant un ou plusieurs des tests suivants:
Functionality testing - Teste toutes les fonctionnalités du logiciel par rapport à l'exigence.
Performance testing- Ce test prouve l'efficacité du logiciel. Il teste l'efficacité et le temps moyen mis par le logiciel pour effectuer la tâche souhaitée. Les tests de performance sont effectués au moyen de tests de charge et de tests de résistance où le logiciel est soumis à une charge élevée d'utilisateurs et de données dans diverses conditions d'environnement.
Security & Portability - Ces tests sont effectués lorsque le logiciel est destiné à fonctionner sur différentes plates-formes et accessible par nombre de personnes.
Test d'acceptation
Lorsque le logiciel est prêt à être remis au client, il doit passer par la dernière phase de test où il est testé pour l'interaction et la réponse de l'utilisateur. Ceci est important car même si le logiciel répond à toutes les exigences de l'utilisateur et si l'utilisateur n'aime pas la façon dont il apparaît ou fonctionne, il peut être rejeté.
Alpha testing- L'équipe de développeurs effectue elle-même des tests alpha en utilisant le système comme s'il était utilisé dans l'environnement de travail. Ils essaient de découvrir comment l'utilisateur réagirait à une action dans le logiciel et comment le système devrait réagir aux entrées.
Beta testing- Une fois le logiciel testé en interne, il est remis aux utilisateurs pour l'utiliser dans leur environnement de production uniquement à des fins de test. Ce n'est pas encore le produit livré. Les développeurs s'attendent à ce que les utilisateurs à ce stade apportent des problèmes infimes, qui ont été ignorés.
Les tests de régression
Chaque fois qu'un produit logiciel est mis à jour avec un nouveau code, une nouvelle fonctionnalité ou une nouvelle fonctionnalité, il est testé de manière approfondie pour détecter s'il y a un impact négatif du code ajouté. Ceci est connu sous le nom de test de régression.
Documentation de test
Les documents de test sont préparés à différentes étapes -
Avant de tester
Les tests commencent par la génération des cas de test. Les documents suivants sont nécessaires pour référence -
SRS document - Document des exigences fonctionnelles
Test Policy document - Ceci décrit dans quelle mesure les tests doivent avoir lieu avant de lancer le produit.
Test Strategy document - Ceci mentionne les aspects détaillés de l'équipe de test, la matrice de responsabilité et les droits / responsabilité du responsable de test et de l'ingénieur de test.
Traceability Matrix document- Il s'agit d'un document SDLC, qui est lié au processus de collecte des exigences. À mesure que de nouvelles exigences se présentent, elles sont ajoutées à cette matrice. Ces matrices aident les testeurs à connaître la source de l'exigence. Ils peuvent être tracés en avant et en arrière.
Pendant le test
Les documents suivants peuvent être requis lors du démarrage et de l'exécution du test:
Test Case document- Ce document contient la liste des tests à réaliser. Il comprend un plan de test unitaire, un plan de test d'intégration, un plan de test système et un plan de test d'acceptation.
Test description - Ce document est une description détaillée de tous les cas de test et des procédures pour les exécuter.
Test case report - Ce document contient un rapport de cas de test à la suite du test.
Test logs - Ce document contient des journaux de test pour chaque rapport de cas de test.
Après le test
Les documents suivants peuvent être générés après les tests:
Test summary- Ce résumé de test est une analyse collective de tous les rapports et journaux de test. Il résume et conclut si le logiciel est prêt à être lancé. Le logiciel est publié sous le système de contrôle de version s'il est prêt à être lancé.
Tests vs contrôle qualité, assurance qualité et audit
Nous devons comprendre que les tests logiciels sont différents de l'assurance qualité logicielle, du contrôle qualité logiciel et de l'audit logiciel.
Software quality assurance- Il s'agit de moyens de suivi des processus de développement logiciel, par lesquels il est assuré que toutes les mesures sont prises conformément aux normes d'organisation. Cette surveillance est effectuée pour s'assurer que les méthodes de développement logiciel appropriées ont été suivies.
Software quality control- Il s'agit d'un système pour maintenir la qualité du produit logiciel. Il peut inclure des aspects fonctionnels et non fonctionnels du produit logiciel, qui améliorent la bonne volonté de l'organisation. Ce système garantit que le client reçoit un produit de qualité pour ses besoins et le produit certifié comme «apte à l'emploi».
Software audit- Il s'agit d'un examen de la procédure utilisée par l'organisation pour développer le logiciel. Une équipe d'auditeurs, indépendante de l'équipe de développement, examine le processus logiciel, la procédure, les exigences et d'autres aspects de SDLC. Le but de l'audit logiciel est de vérifier que le logiciel et son processus de développement sont conformes aux normes, règles et réglementations.
La maintenance logicielle est désormais largement acceptée dans le SDLC. Il représente toutes les modifications et mises à jour effectuées après la livraison du produit logiciel. Il y a un certain nombre de raisons pour lesquelles des modifications sont nécessaires, certaines d'entre elles sont brièvement mentionnées ci-dessous:
Market Conditions - Les politiques, qui changent au fil du temps, telles que la fiscalité et les contraintes nouvellement introduites telles que la façon de tenir la comptabilité, peuvent nécessiter des modifications.
Client Requirements - Au fil du temps, le client peut demander de nouvelles fonctionnalités ou fonctions dans le logiciel.
Host Modifications - Si l'un des matériels et / ou plates-formes (tels que le système d'exploitation) de l'hôte cible change, des modifications logicielles sont nécessaires pour conserver l'adaptabilité.
Organization Changes - S'il y a un changement au niveau de l'entreprise du côté du client, comme la réduction de la force de l'organisation, l'acquisition d'une autre entreprise, l'organisation s'aventurant dans une nouvelle entreprise, il peut se produire un besoin de modifier le logiciel d'origine.
Types de maintenance
Au cours de la vie d'un logiciel, le type de maintenance peut varier en fonction de sa nature. Il peut s'agir simplement de tâches de maintenance de routine comme un bogue découvert par un utilisateur ou d'un événement important en soi en fonction de la taille ou de la nature de la maintenance. Voici quelques types de maintenance en fonction de leurs caractéristiques:
Corrective Maintenance - Cela inclut les modifications et les mises à jour effectuées afin de corriger ou de résoudre les problèmes, qui sont soit découverts par l'utilisateur, soit conclus par des rapports d'erreur de l'utilisateur.
Adaptive Maintenance - Cela comprend les modifications et les mises à jour appliquées pour maintenir le produit logiciel à jour et à l'écoute du monde en constante évolution de la technologie et de l'environnement commercial.
Perfective Maintenance- Cela comprend les modifications et les mises à jour effectuées afin de garder le logiciel utilisable sur une longue période de temps. Il comprend de nouvelles fonctionnalités, de nouvelles exigences des utilisateurs pour affiner le logiciel et améliorer sa fiabilité et ses performances.
Preventive Maintenance- Cela inclut les modifications et les mises à jour pour éviter de futurs problèmes du logiciel. Il vise à répondre aux problèmes, qui ne sont pas significatifs pour le moment, mais peuvent causer de graves problèmes à l'avenir.
Coût d'entretien
Les rapports suggèrent que le coût de la maintenance est élevé. Une étude sur l'estimation de la maintenance logicielle a révélé que le coût de la maintenance peut atteindre 67% du coût du cycle complet du processus logiciel.
En moyenne, le coût de la maintenance logicielle est supérieur à 50% de toutes les phases du SDLC. Il existe divers facteurs qui déclenchent des coûts de maintenance élevés, tels que:
Facteurs du monde réel affectant les coûts de maintenance
- L'âge standard de tout logiciel est considéré comme allant de 10 à 15 ans.
- Les logiciels plus anciens, qui étaient censés fonctionner sur des machines lentes avec moins de mémoire et de capacité de stockage, ne peuvent pas se battre contre les nouveaux logiciels améliorés sur du matériel moderne.
- À mesure que la technologie progresse, il devient coûteux de maintenir les anciens logiciels.
- La plupart des ingénieurs de maintenance sont débutants et utilisent une méthode d'essai et d'erreur pour résoudre le problème.
- Souvent, les modifications apportées peuvent facilement endommager la structure d'origine du logiciel, ce qui rend difficile toute modification ultérieure.
- Les changements sont souvent laissés sans documentation, ce qui peut entraîner davantage de conflits à l'avenir.
Facteurs de fin de logiciel affectant le coût de maintenance
- Structure du programme logiciel
- Langage de programmation
- Dépendance à l'environnement extérieur
- Fiabilité et disponibilité du personnel
Activités de maintenance
IEEE fournit un cadre pour les activités de processus de maintenance séquentielle. Il peut être utilisé de manière itérative et peut être étendu afin que des éléments et des processus personnalisés puissent être inclus.
Ces activités vont de pair avec chacune des phases suivantes:
Identification & Tracing- Il s'agit d'activités relatives à l'identification des besoins de modification ou de maintenance. Il est généré par l'utilisateur ou le système peut lui-même signaler via des journaux ou des messages d'erreur. Ici, le type de maintenance est également classé.
Analysis- La modification est analysée pour son impact sur le système, y compris les implications en matière de sûreté et de sécurité. Si l'impact probable est grave, une solution alternative est recherchée. Un ensemble de modifications requises est ensuite matérialisé en spécifications d'exigences. Le coût de modification / maintenance est analysé et l'estimation est conclue.
Design- Les nouveaux modules, qui doivent être remplacés ou modifiés, sont conçus en fonction des spécifications d'exigences définies à l'étape précédente. Les cas de test sont créés pour la validation et la vérification.
Implementation - Les nouveaux modules sont codés à l'aide d'une conception structurée créée lors de l'étape de conception. Chaque programmeur est censé faire des tests unitaires en parallèle.
System Testing- Les tests d'intégration sont effectués parmi les modules nouvellement créés. Des tests d'intégration sont également effectués entre les nouveaux modules et le système. Enfin, le système est testé dans son ensemble, suivant des procédures de tests régressifs.
Acceptance Testing- Après avoir testé le système en interne, son acceptation est testée avec l'aide des utilisateurs. Si, dans cet état, l'utilisateur se plaint de certains problèmes qu'il est résolu ou qu'il doit résoudre lors de la prochaine itération.
Delivery- Après le test d'acceptation, le système est déployé dans toute l'organisation soit par un petit package de mise à jour, soit par une nouvelle installation du système. Le test final a lieu à la fin du client après la livraison du logiciel.
Une installation de formation est fournie si nécessaire, en plus de la copie papier du manuel d'utilisation.
Maintenance management- La gestion de la configuration est une partie essentielle de la maintenance du système. Il est accompagné d'outils de contrôle de version pour contrôler les versions, les semi-versions ou la gestion des correctifs.
Réingénierie logicielle
Lorsque nous avons besoin de mettre à jour le logiciel pour le maintenir sur le marché actuel, sans affecter sa fonctionnalité, cela s'appelle la réingénierie logicielle. Il s'agit d'un processus approfondi où la conception du logiciel est modifiée et les programmes sont réécrits.
Les logiciels hérités ne peuvent pas continuer à s'accorder avec les dernières technologies disponibles sur le marché. Comme le matériel devient obsolète, la mise à jour du logiciel devient un casse-tête. Même si le logiciel vieillit avec le temps, sa fonctionnalité ne l'est pas.
Par exemple, au départ, Unix a été développé en langage d'assemblage. Lorsque le langage C est né, Unix a été repensé en C, car travailler en langage d'assemblage était difficile.
En dehors de cela, les programmeurs remarquent parfois que peu de parties du logiciel nécessitent plus de maintenance que d'autres et ont également besoin d'une réingénierie.
Processus de réingénierie
- Decidequoi restructurer. S'agit-il d'un logiciel entier ou d'une partie de celui-ci?
- Perform Reverse Engineering, afin d'obtenir les spécifications des logiciels existants.
- Restructure Programsi nécessaire. Par exemple, changer des programmes orientés fonction en programmes orientés objet.
- Re-structure data comme demandé.
- Apply Forward engineering concepts afin d'obtenir un logiciel repensé.
Il y a peu de termes importants utilisés dans la réingénierie logicielle
Ingénierie inverse
Il s'agit d'un processus pour atteindre la spécification du système en analysant et en comprenant le système existant. Ce processus peut être vu comme un modèle SDLC inversé, c'est-à-dire que nous essayons d'obtenir un niveau d'abstraction plus élevé en analysant des niveaux d'abstraction inférieurs.
Un système existant est une conception précédemment mise en œuvre, dont nous ne savons rien. Les concepteurs font ensuite de la rétro-ingénierie en examinant le code et tentent d'obtenir la conception. Avec la conception en main, ils essaient de conclure les spécifications. Ainsi, aller en sens inverse du code à la spécification du système.
Restructuration du programme
Il s'agit d'un processus de restructuration et de reconstruction du logiciel existant. Il s'agit de réorganiser le code source, soit dans le même langage de programmation, soit d'un langage de programmation à un autre. La restructuration peut avoir soit une restructuration du code source et une restructuration des données, soit les deux.
La restructuration n'affecte pas la fonctionnalité du logiciel mais améliore la fiabilité et la maintenabilité. Les composants du programme, qui provoquent des erreurs très fréquemment, peuvent être modifiés ou mis à jour avec une restructuration.
La fiabilité des logiciels sur une plate-forme matérielle obsolète peut être supprimée via une restructuration.
Ingénierie avancée
L'ingénierie avancée est un processus d'obtention du logiciel souhaité à partir des spécifications en main qui ont été réduites au moyen de l'ingénierie inverse. Cela suppose qu'il y avait déjà du génie logiciel dans le passé.
L'ingénierie avancée est identique au processus d'ingénierie logicielle avec une seule différence - elle est toujours réalisée après l'ingénierie inverse.
Réutilisabilité des composants
Un composant fait partie du code de programme logiciel, qui exécute une tâche indépendante dans le système. Il peut s'agir d'un petit module ou d'un sous-système lui-même.
Exemple
Les procédures de connexion utilisées sur le Web peuvent être considérées comme des composants, le système d'impression dans le logiciel peut être considéré comme un composant du logiciel.
Les composants ont une haute cohésion de fonctionnalité et un taux de couplage plus faible, c'est-à-dire qu'ils fonctionnent indépendamment et peuvent effectuer des tâches sans dépendre d'autres modules.
En POO, les objets conçus sont très spécifiques à leur préoccupation et ont moins de chances d'être utilisés dans d'autres logiciels.
Dans la programmation modulaire, les modules sont codés pour effectuer des tâches spécifiques qui peuvent être utilisées dans de nombreux autres programmes logiciels.
Il existe une toute nouvelle verticale, basée sur la réutilisation de composants logiciels, connue sous le nom de Génie logiciel basé sur les composants (CBSE).
La réutilisation peut être effectuée à différents niveaux
Application level - Lorsqu'une application entière est utilisée comme sous-système d'un nouveau logiciel.
Component level - Où le sous-système d'une application est utilisé.
Modules level - Où les modules fonctionnels sont réutilisés.
Les composants logiciels fournissent des interfaces qui peuvent être utilisées pour établir la communication entre différents composants.
Processus de réutilisation
Deux types de méthode peuvent être adoptés: soit en conservant les mêmes exigences et en ajustant les composants, soit en conservant les mêmes composants et en modifiant les exigences.
Requirement Specification - Les exigences fonctionnelles et non fonctionnelles sont spécifiées, auxquelles un logiciel doit se conformer, à l'aide du système existant, des entrées de l'utilisateur ou des deux.
Design- Il s'agit également d'une étape de processus SDLC standard, où les exigences sont définies en termes de langage logiciel. L'architecture de base du système dans son ensemble et de ses sous-systèmes est créée.
Specify Components - En étudiant la conception du logiciel, les concepteurs séparent l'ensemble du système en composants ou sous-systèmes plus petits. Une conception logicielle complète se transforme en une collection d'un vaste ensemble de composants travaillant ensemble.
Search Suitable Components - Le référentiel de composants logiciels est référencé par les concepteurs pour rechercher le composant correspondant, sur la base des fonctionnalités et des exigences logicielles prévues.
Incorporate Components - Tous les composants correspondants sont emballés ensemble pour les façonner en tant que logiciel complet.
CASE signifie Cordinateur Aided Software Engineering. Cela signifie, développement et maintenance de projets logiciels à l'aide de divers outils logiciels automatisés.
Outils CASE
Les outils CASE sont un ensemble de programmes d'application logicielle, qui sont utilisés pour automatiser les activités SDLC. Les outils CASE sont utilisés par les gestionnaires de projets logiciels, les analystes et les ingénieurs pour développer un système logiciel.
Il existe un certain nombre d'outils CASE disponibles pour simplifier les différentes étapes du cycle de vie du développement logiciel tels que les outils d'analyse, les outils de conception, les outils de gestion de projet, les outils de gestion de base de données, les outils de documentation, pour n'en nommer que quelques-uns.
L'utilisation des outils CASE accélère le développement du projet pour produire le résultat souhaité et aide à découvrir les failles avant de passer à l'étape suivante du développement logiciel.
Composants des outils CASE
Les outils CASE peuvent être globalement divisés en les parties suivantes en fonction de leur utilisation à une étape particulière du SDLC:
Central Repository- Les outils CASE nécessitent un référentiel central, qui peut servir de source d'informations communes, intégrées et cohérentes. Le référentiel central est un lieu de stockage central où sont stockées les spécifications du produit, les documents d'exigences, les rapports et diagrammes associés, ainsi que d'autres informations utiles concernant la gestion. Le référentiel central sert également de dictionnaire de données.
Upper Case Tools - Les outils Upper CASE sont utilisés dans les étapes de planification, d'analyse et de conception du SDLC.
Lower Case Tools - Les outils CASE inférieurs sont utilisés dans la mise en œuvre, les tests et la maintenance.
Integrated Case Tools - Les outils CASE intégrés sont utiles à toutes les étapes du SDLC, de la collecte des exigences aux tests et à la documentation.
Les outils CASE peuvent être regroupés s'ils ont des fonctionnalités, des activités de processus et une capacité similaires à s'intégrer à d'autres outils.
Portée des outils de cas
La portée des outils CASE s'étend à l'ensemble du SDLC.
Types d'outils de cas
Maintenant, nous passons brièvement en revue divers outils CASE
Outils de diagramme
Ces outils sont utilisés pour représenter les composants du système, les données et le flux de contrôle entre divers composants logiciels et la structure du système sous forme graphique. Par exemple, l'outil Flow Chart Maker pour créer des organigrammes à la pointe de la technologie.
Outils de modélisation de processus
La modélisation de processus est une méthode pour créer un modèle de processus logiciel, qui est utilisé pour développer le logiciel. Les outils de modélisation de processus aident les gestionnaires à choisir un modèle de processus ou à le modifier selon les exigences du produit logiciel. Par exemple, EPF Composer
Outils de gestion de projet
Ces outils sont utilisés pour la planification de projet, l'estimation des coûts et des efforts, la planification des projets et la planification des ressources. Les gestionnaires doivent se conformer strictement à l'exécution du projet à chaque étape mentionnée dans la gestion de projet logiciel. Les outils de gestion de projet aident à stocker et à partager les informations de projet en temps réel dans toute l'organisation. Par exemple, Creative Pro Office, Trac Project, Basecamp.
Outils de documentation
La documentation d'un projet logiciel commence avant le processus logiciel, s'étend à toutes les phases du SDLC et après l'achèvement du projet.
Les outils de documentation génèrent des documents pour les utilisateurs techniques et les utilisateurs finaux. Les utilisateurs techniques sont pour la plupart des professionnels internes de l'équipe de développement qui se réfèrent au manuel du système, au manuel de référence, au manuel de formation, aux manuels d'installation, etc. Les documents de l'utilisateur final décrivent le fonctionnement et la marche à suivre du système tels que le manuel d'utilisation. Par exemple, Doxygen, DrExplain, Adobe RoboHelp pour la documentation.
Outils d'analyse
Ces outils permettent de rassembler les exigences, de vérifier automatiquement toute incohérence, inexactitude dans les diagrammes, redondances de données ou omissions erronées. Par exemple, Accept 360, Accompa, CaseComplete pour l'analyse des besoins, Visible Analyst pour l'analyse totale.
Outils de conception
Ces outils aident les concepteurs de logiciels à concevoir la structure en blocs du logiciel, qui peut être ensuite décomposée en modules plus petits à l'aide de techniques de raffinement. Ces outils fournissent des détails sur chaque module et les interconnexions entre les modules. Par exemple, conception de logiciels animés
Outils de gestion de la configuration
Une instance de logiciel est publiée sous une seule version. Les outils de gestion de la configuration traitent -
- Gestion des versions et des révisions
- Gestion de la configuration de base
- Gestion du contrôle des changements
Les outils CASE y contribuent par le suivi automatique, la gestion des versions et la gestion des versions. Par exemple, Fossil, Git, Accu REV.
Modifier les outils de contrôle
Ces outils sont considérés comme faisant partie des outils de gestion de configuration. Ils traitent des modifications apportées au logiciel après la fixation de sa base de référence ou lors de la première publication du logiciel. Les outils CASE automatisent le suivi des modifications, la gestion des fichiers, la gestion du code et plus encore. Cela aide également à appliquer la politique de changement de l'organisation.
Outils de programmation
Ces outils se composent d'environnements de programmation tels que IDE (Integrated Development Environment), d'une bibliothèque de modules intégrés et d'outils de simulation. Ces outils fournissent une aide complète dans la création de produits logiciels et incluent des fonctionnalités de simulation et de test. Par exemple, Cscope pour rechercher du code en C, Eclipse.
Outils de prototypage
Le prototype logiciel est une version simulée du produit logiciel prévu. Le prototype fournit l'aspect et la sensation initiaux du produit et simule quelques aspects du produit réel.
Prototypage Les outils CASE sont essentiellement fournis avec des bibliothèques graphiques. Ils peuvent créer des interfaces utilisateur et une conception indépendantes du matériel. Ces outils nous aident à construire des prototypes rapides basés sur des informations existantes. En outre, ils fournissent une simulation de prototype de logiciel. Par exemple, Serena prototype compositeur, Mockup Builder.
Outils de développement Web
Ces outils aident à concevoir des pages Web avec tous les éléments associés tels que les formulaires, le texte, le script, les graphiques, etc. Les outils Web fournissent également un aperçu en direct de ce qui est en cours de développement et de son apparence une fois terminé. Par exemple, Fontello, Adobe Edge Inspect, Foundation 3, Brackets.
Outils d'assurance qualité
L'assurance qualité dans une organisation logicielle surveille le processus d'ingénierie et les méthodes adoptées pour développer le produit logiciel afin de garantir la conformité de la qualité selon les normes de l'organisation. Les outils d'assurance qualité se composent d'outils de configuration et de contrôle des modifications et d'outils de test logiciel. Par exemple, SoapTest, AppsWatch, JMeter.
Outils de maintenance
La maintenance logicielle comprend les modifications du produit logiciel après sa livraison. Les techniques de journalisation automatique et de rapport d'erreurs, la génération automatique de tickets d'erreur et l'analyse des causes profondes sont quelques-uns des outils CASE, qui aident l'organisation logicielle dans la phase de maintenance du SDLC. Par exemple, Bugzilla pour le suivi des défauts, HP Quality Center.