Ingegneria del software - Guida rapida

Cerchiamo prima di capire cosa significa ingegneria del software. Il termine è composto da due parole, software e ingegneria.

Software è più di un semplice codice di programma. Un programma è un codice eseguibile, che ha uno scopo computazionale. Il software è considerato una raccolta di codice di programmazione eseguibile, librerie associate e documentazioni. Viene chiamato il software, se creato per un requisito specificosoftware product.

Engineering d'altra parte, si tratta di sviluppare prodotti, utilizzando principi e metodi scientifici ben definiti.

Software engineeringè una branca dell'ingegneria associata allo sviluppo di prodotti software utilizzando principi, metodi e procedure scientifici ben definiti. Il risultato dell'ingegneria del software è un prodotto software efficiente e affidabile.

Definizioni

IEEE definisce l'ingegneria del software come:

(1) l'applicazione di un approccio sistematico, disciplinato e quantificabile allo sviluppo, al funzionamento e alla manutenzione del software; cioè l'applicazione dell'ingegneria al software.

(2) Lo studio degli approcci come nella dichiarazione di cui sopra.

Fritz Bauer, uno scienziato informatico tedesco, definisce l'ingegneria del software come:

L'ingegneria del software è la creazione e l'uso di solidi principi di ingegneria al fine di ottenere un software economicamente affidabile e che funzioni in modo efficiente su macchine reali.

Evoluzione del software

Il processo di sviluppo di un prodotto software utilizzando principi e metodi di ingegneria del software è indicato come software evolution. Ciò include lo sviluppo iniziale del software e la sua manutenzione e aggiornamenti, fino allo sviluppo del prodotto software desiderato, che soddisfa i requisiti previsti.

L'evoluzione parte dal processo di raccolta dei requisiti. Dopo di che gli sviluppatori creano un prototipo del software previsto e lo mostrano agli utenti per ottenere il loro feedback nella fase iniziale dello sviluppo del prodotto software. Gli utenti suggeriscono modifiche, su cui continuano a cambiare anche diversi aggiornamenti e manutenzioni consecutivi. Questo processo passa al software originale, fino a quando il software desiderato non viene completato.

Anche dopo che l'utente ha desiderato il software in mano, la tecnologia avanzata e le mutevoli esigenze costringono il prodotto software a cambiare di conseguenza. Ricreare il software da zero e andare uno contro uno con i requisiti non è fattibile. L'unica soluzione fattibile ed economica è aggiornare il software esistente in modo che soddisfi i requisiti più recenti.

Leggi sull'evoluzione del software

Lehman ha dato leggi per l'evoluzione del software. Ha diviso il software in tre diverse categorie:

  • S-type (static-type) - Questo è un software che funziona rigorosamente secondo specifiche e soluzioni definite . La soluzione e il metodo per ottenerlo, entrambi sono immediatamente compresi prima della codifica. Il software di tipo s è meno soggetto a modifiche, quindi questo è il più semplice di tutti. Ad esempio, programma calcolatrice per calcoli matematici.
  • P-type (practical-type) - Questo è un software con una raccolta di procedure. Questo è definito esattamente da ciò che le procedure possono fare. In questo software, le specifiche possono essere descritte ma la soluzione non è immediatamente evidente. Ad esempio, software di gioco.
  • E-type (embedded-type) - Questo software funziona da vicino come requisito dell'ambiente del mondo reale. Questo software ha un alto grado di evoluzione in quanto ci sono vari cambiamenti nelle leggi, tasse ecc. Nelle situazioni del mondo reale. Ad esempio, software di trading online.

Evoluzione del software E-Type

Lehman ha fornito otto leggi per l'evoluzione del software E-Type:

  • Continuing change - Un sistema software di tipo E deve continuare ad adattarsi ai cambiamenti del mondo reale, altrimenti diventa progressivamente meno utile.
  • Increasing complexity - Man mano che un sistema software di tipo E si evolve, la sua complessità tende ad aumentare a meno che non si lavori per mantenerlo o ridurlo.
  • Conservation of familiarity - La familiarità con il software o la conoscenza di come è stato sviluppato, perché è stato sviluppato in quel particolare modo ecc. Devono essere mantenute ad ogni costo, per implementare i cambiamenti nel sistema.
  • Continuing growth- Affinché un sistema di tipo E destinato a risolvere alcuni problemi aziendali, la sua dimensione di implementazione dei cambiamenti cresce in base ai cambiamenti dello stile di vita dell'azienda.
  • Reducing quality - Un sistema software di tipo E diminuisce di qualità a meno che non venga mantenuto e adattato rigorosamente a un ambiente operativo in evoluzione.
  • Feedback systems- I sistemi software di tipo E costituiscono sistemi di feedback multi-loop e multi-livello e devono essere trattati come tali per essere modificati o migliorati con successo.
  • Self-regulation - I processi di evoluzione del sistema di tipo E si autoregolano con la distribuzione di misure di prodotto e processo vicine alla normalità.
  • Organizational stability - Il tasso di attività globale medio effettivo in un sistema di tipo E in evoluzione è invariante per tutta la durata del prodotto.

Paradigmi software

I paradigmi software si riferiscono ai metodi e ai passaggi che vengono eseguiti durante la progettazione del software. Ci sono molti metodi proposti e sono in funzione oggi, ma dobbiamo vedere dove si trovano questi paradigmi nell'ingegneria del software. Questi possono essere combinati in varie categorie, sebbene ciascuna di esse sia contenuta l'una nell'altra:

Il paradigma di programmazione è un sottoinsieme del paradigma di progettazione del software che è ulteriormente un sottoinsieme del paradigma di sviluppo del software.

Paradigma dello sviluppo del software

Questo paradigma è noto come paradigmi di ingegneria del software in cui vengono applicati tutti i concetti di ingegneria relativi allo sviluppo del software. Comprende varie ricerche e raccolta di requisiti che aiutano la creazione del prodotto software. Consiste in -

  • Raccolta dei requisiti
  • Progettazione software
  • Programming

Paradigma di progettazione del software

Questo paradigma fa parte dello sviluppo software e include:

  • Design
  • Maintenance
  • Programming

Paradigma di programmazione

Questo paradigma è strettamente correlato all'aspetto della programmazione dello sviluppo del software. Ciò comprende -

  • Coding
  • Testing
  • Integration

Necessità di ingegneria del software

La necessità dell'ingegneria del software nasce a causa della maggiore velocità di variazione dei requisiti dell'utente e dell'ambiente su cui il software sta lavorando.

  • Large software - È più facile costruire un muro che una casa o un edificio, allo stesso modo, poiché le dimensioni del software diventano grandi, l'ingegneria deve intervenire per dargli un processo scientifico.
  • Scalability- Se il processo del software non fosse basato su concetti scientifici e ingegneristici, sarebbe più facile ricreare un nuovo software che scalarne uno esistente.
  • Cost- Poiché l'industria dell'hardware ha dimostrato le sue capacità e l'enorme produzione ha abbassato il prezzo dei computer e dell'hardware elettronico. Ma il costo del software rimane elevato se il processo corretto non viene adattato.
  • Dynamic Nature- La natura sempre crescente e adattabile del software dipende enormemente dall'ambiente in cui l'utente lavora. Se la natura del software cambia continuamente, è necessario apportare nuovi miglioramenti a quello esistente. È qui che l'ingegneria del software gioca un buon ruolo.
  • Quality Management- Un migliore processo di sviluppo del software fornisce un prodotto software migliore e di qualità.

Caratteristiche di un buon software

Un prodotto software può essere giudicato in base a ciò che offre e al modo in cui può essere utilizzato. Questo software deve soddisfare i seguenti motivi:

  • Operational
  • Transitional
  • Maintenance

Si prevede che un software ben progettato e realizzato abbia le seguenti caratteristiche:

Operativo

Questo ci dice quanto bene il software funziona nelle operazioni. Può essere misurato su:

  • Budget
  • Usability
  • Efficiency
  • Correctness
  • Functionality
  • Dependability
  • Security
  • Safety

Di transizione

Questo aspetto è importante quando il software viene spostato da una piattaforma all'altra:

  • Portability
  • Interoperability
  • Reusability
  • Adaptability

Manutenzione

Questo aspetto riassume quanto bene un software abbia le capacità di mantenersi in un ambiente in continua evoluzione:

  • Modularity
  • Maintainability
  • Flexibility
  • Scalability

In breve, l'ingegneria del software è una branca dell'informatica, che utilizza concetti di ingegneria ben definiti necessari per produrre prodotti software efficienti, durevoli, scalabili, in budget e puntuali.

Il ciclo di vita dello sviluppo del software, abbreviato in SDLC, è una sequenza ben definita e strutturata di fasi nell'ingegneria del software per sviluppare il prodotto software previsto.

Attività SDLC

SDLC fornisce una serie di passaggi da seguire per progettare e sviluppare un prodotto software in modo efficiente. Il framework SDLC include i seguenti passaggi:

Comunicazione

Questo è il primo passaggio in cui l'utente avvia la richiesta di un prodotto software desiderato. Contatta il fornitore di servizi e cerca di negoziare i termini. Inoltra la sua richiesta per iscritto all'organizzazione che fornisce il servizio.

Raccolta dei requisiti

In questo passaggio il team di sviluppo software lavora per portare avanti il ​​progetto. Il team tiene discussioni con varie parti interessate dal dominio del problema e cerca di fornire quante più informazioni possibili sulle loro esigenze. I requisiti sono contemplati e separati in requisiti dell'utente, requisiti di sistema e requisiti funzionali. I requisiti vengono raccolti utilizzando una serie di pratiche fornite:

  • studiare il sistema e il software esistenti o obsoleti,
  • condurre interviste a utenti e sviluppatori,
  • riferendosi al database o
  • raccogliere risposte dai questionari.

Studio di fattibilità

Dopo la raccolta dei requisiti, il team presenta un piano approssimativo del processo software. In questa fase il team analizza se un software può essere realizzato per soddisfare tutti i requisiti dell'utente e se esiste la possibilità che il software non sia più utile. Si scopre se il progetto è finanziariamente, praticamente e tecnologicamente fattibile per l'organizzazione. Sono disponibili molti algoritmi che aiutano gli sviluppatori a concludere la fattibilità di un progetto software.

Analisi del sistema

A questo punto gli sviluppatori decidono una roadmap del loro piano e cercano di far apparire il miglior modello di software adatto al progetto. L'analisi del sistema include la comprensione dei limiti del prodotto software, i problemi relativi al sistema di apprendimento o le modifiche da apportare in anticipo ai sistemi esistenti, l'identificazione e la gestione dell'impatto del progetto sull'organizzazione e sul personale, ecc. Il team di progetto analizza l'ambito del progetto e pianifica il programma e risorse di conseguenza.

Progettazione software

Il passaggio successivo consiste nel ridurre l'intera conoscenza dei requisiti e dell'analisi sulla scrivania e progettare il prodotto software. Gli input degli utenti e le informazioni raccolte nella fase di raccolta dei requisiti sono gli input di questo passaggio. Il risultato di questo passaggio si presenta sotto forma di due modelli; progettazione logica e progettazione fisica. Gli ingegneri producono meta-dati e dizionari di dati, diagrammi logici, diagrammi di flusso di dati e in alcuni casi pseudo codici.

Codifica

Questo passaggio è noto anche come fase di programmazione. L'implementazione della progettazione del software inizia in termini di scrittura del codice del programma nel linguaggio di programmazione appropriato e sviluppo efficiente di programmi eseguibili privi di errori.

Test

Una stima dice che il 50% dell'intero processo di sviluppo del software dovrebbe essere testato. Gli errori possono rovinare il software dal livello critico alla sua rimozione. Il test del software viene eseguito durante la codifica da parte degli sviluppatori e il test approfondito viene condotto da esperti di test a vari livelli di codice come test del modulo, test del programma, test del prodotto, test interno e test del prodotto presso l'utente. La scoperta precoce degli errori e il loro rimedio è la chiave per un software affidabile.

Integrazione

Potrebbe essere necessario integrare il software con le librerie, i database e altri programmi. Questa fase dell'SDLC è coinvolta nell'integrazione del software con entità del mondo esterno.

Implementazione

Ciò significa installare il software sulle macchine degli utenti. A volte, il software necessita di configurazioni post-installazione da parte dell'utente. Il software viene testato per la portabilità e l'adattabilità e i problemi relativi all'integrazione vengono risolti durante l'implementazione.

Funzionamento e manutenzione

Questa fase conferma il funzionamento del software in termini di maggiore efficienza e minori errori. Se necessario, gli utenti vengono formati o aiutati con la documentazione su come utilizzare il software e su come mantenerlo operativo. Il software viene mantenuto tempestivamente aggiornando il codice in base ai cambiamenti in atto nell'ambiente o nella tecnologia dell'utente finale. Questa fase può affrontare sfide da bug nascosti e problemi non identificati del mondo reale.

Disposizione

Con il passare del tempo, il software potrebbe diminuire sul fronte delle prestazioni. Potrebbe diventare completamente obsoleto o potrebbe richiedere un aggiornamento intenso. Da qui nasce una pressante necessità di eliminare una parte importante del sistema. Questa fase include l'archiviazione dei dati e dei componenti software richiesti, la chiusura del sistema, la pianificazione dell'attività di smaltimento e la chiusura del sistema all'ora di fine sistema appropriata.

Paradigma dello sviluppo del software

Il paradigma di sviluppo del software aiuta lo sviluppatore a selezionare una strategia per sviluppare il software. Un paradigma di sviluppo software ha un proprio insieme di strumenti, metodi e procedure, che sono espressi chiaramente e definiscono il ciclo di vita dello sviluppo del software. Alcuni paradigmi di sviluppo software o modelli di processo sono definiti come segue:

Modello a cascata

Il modello a cascata è il modello più semplice del paradigma di sviluppo software. Dice che tutte le fasi dell'SDLC funzioneranno una dopo l'altra in modo lineare. Cioè, quando la prima fase è finita, inizierà solo la seconda e così via.

Questo modello presuppone che tutto sia svolto e si sia svolto perfettamente come pianificato nella fase precedente e non è necessario pensare ai problemi passati che potrebbero sorgere nella fase successiva. Questo modello non funziona correttamente se sono presenti alcuni problemi nel passaggio precedente. La natura sequenziale del modello non ci consente di tornare indietro e annullare o ripetere le nostre azioni.

Questo modello è più adatto quando gli sviluppatori hanno già progettato e sviluppato software simile in passato e sono a conoscenza di tutti i suoi domini.

Modello iterativo

Questo modello guida il processo di sviluppo del software in iterazioni. Proietta il processo di sviluppo in modo ciclico ripetendo ogni passaggio dopo ogni ciclo del processo SDLC.

Il software viene prima sviluppato su scala molto piccola e vengono seguiti tutti i passaggi che vengono presi in considerazione. Quindi, ad ogni iterazione successiva, più funzionalità e moduli vengono progettati, codificati, testati e aggiunti al software. Ogni ciclo produce un software, che è completo in sé e ha più caratteristiche e capacità di quello del precedente.

Dopo ogni iterazione, il team di gestione può lavorare sulla gestione del rischio e prepararsi per l'iterazione successiva. Poiché un ciclo include una piccola porzione dell'intero processo software, è più facile gestire il processo di sviluppo ma consuma più risorse.

Modello a spirale

Il modello a spirale è una combinazione di entrambi, il modello iterativo e uno del modello SDLC. Può essere visto come se si scelga un modello SDLC e lo si combini con un processo ciclico (modello iterativo).

Questo modello considera il rischio, che spesso non viene notato dalla maggior parte degli altri modelli. Il modello inizia con la determinazione degli obiettivi e dei vincoli del software all'inizio di un'iterazione. La fase successiva è la prototipazione del software. Ciò include l'analisi del rischio. Quindi un modello SDLC standard viene utilizzato per creare il software. Nella quarta fase viene preparato il piano della prossima iterazione.

V - modello

Il principale svantaggio del modello a cascata è che si passa alla fase successiva solo quando quella precedente è terminata e non c'era alcuna possibilità di tornare indietro se si riscontrano problemi nelle fasi successive. V-Model fornisce mezzi per testare il software in ogni fase in modo inverso.

In ogni fase, vengono creati piani di test e casi di test per verificare e convalidare il prodotto in base ai requisiti di quella fase. Ad esempio, nella fase di raccolta dei requisiti il ​​team di test prepara tutti i casi di test in corrispondenza dei requisiti. Successivamente, quando il prodotto viene sviluppato ed è pronto per il test, i casi di test di questa fase verificano la validità del software rispetto ai requisiti in questa fase.

Ciò fa sì che la verifica e la convalida vadano in parallelo. Questo modello è noto anche come modello di verifica e convalida.

Modello Big Bang

Questo modello è il modello più semplice nella sua forma. Richiede poca pianificazione, molta programmazione e molti fondi. Questo modello è concettualizzato intorno al big bang dell'universo. Come dicono gli scienziati, dopo il big bang molte galassie, pianeti e stelle si sono evoluti come un evento. Allo stesso modo, se mettiamo insieme un sacco di programmazione e fondi, potresti ottenere il miglior prodotto software.

Per questo modello è richiesta una pianificazione minima. Non segue alcun processo, oa volte il cliente non è sicuro dei requisiti e delle esigenze future. Quindi i requisiti di input sono arbitrari.

Questo modello non è adatto per grandi progetti software, ma buono per l'apprendimento e la sperimentazione.

Per una lettura approfondita su SDLC e sui suoi vari modelli, clicca qui.

Il modello di lavoro di un'azienda IT impegnata nello sviluppo di software può essere visto suddiviso in due parti:

  • Creazione di software
  • Gestione dei progetti software

Un progetto è un'attività ben definita, che è una raccolta di diverse operazioni eseguite per raggiungere un obiettivo (ad esempio, sviluppo e consegna del software). Un progetto può essere caratterizzato come:

  • Ogni progetto può avere un obiettivo unico e distinto.
  • Il progetto non è un'attività di routine o operazioni quotidiane.
  • Il progetto viene fornito con un'ora di inizio e un'ora di fine.
  • Il progetto termina quando il suo obiettivo viene raggiunto, quindi è una fase temporanea nella vita di un'organizzazione.
  • Il progetto necessita di risorse adeguate in termini di tempo, manodopera, finanza, materiale e banca della conoscenza.

Progetto software

Un progetto software è la procedura completa di sviluppo del software dalla raccolta dei requisiti al test e alla manutenzione, eseguita secondo le metodologie di esecuzione, in un periodo di tempo specificato per ottenere il prodotto software previsto.

Necessità di gestione del progetto software

Si dice che il software sia un prodotto intangibile. Lo sviluppo del software è una sorta di flusso completamente nuovo nel mondo degli affari e c'è pochissima esperienza nella creazione di prodotti software. La maggior parte dei prodotti software sono realizzati su misura per soddisfare le esigenze del cliente. La cosa più importante è che la tecnologia sottostante cambia e avanza così frequentemente e rapidamente che l'esperienza di un prodotto potrebbe non essere applicata all'altro. Tutti questi vincoli aziendali e ambientali comportano rischi nello sviluppo del software, quindi è essenziale gestire i progetti software in modo efficiente.

L'immagine sopra mostra i tripli vincoli per i progetti software. È una parte essenziale dell'organizzazione del software fornire un prodotto di qualità, mantenendo il costo entro i limiti del budget del cliente e consegnare il progetto come da programma. Ci sono diversi fattori, sia interni che esterni, che possono influire su questo triplo triangolo vincolante. Uno qualsiasi dei tre fattori può avere un impatto grave sugli altri due.

Pertanto, la gestione del progetto software è essenziale per incorporare i requisiti degli utenti insieme ai vincoli di budget e di tempo.

Responsabile di progetto software

Un software project manager è una persona che si assume la responsabilità di eseguire il progetto software. Il responsabile del progetto software è perfettamente consapevole di tutte le fasi dell'SDLC che il software dovrebbe attraversare. Il project manager non può mai coinvolgere direttamente nella produzione del prodotto finale, ma controlla e gestisce le attività coinvolte nella produzione.

Un project manager monitora da vicino il processo di sviluppo, prepara ed esegue vari piani, organizza le risorse necessarie e adeguate, mantiene la comunicazione tra tutti i membri del team al fine di affrontare questioni di costi, budget, risorse, tempo, qualità e soddisfazione del cliente.

Vediamo alcune responsabilità che si assume un project manager:

Gestione delle persone

  • Agisci come capo progetto
  • Lesione con gli stakeholder
  • Gestione delle risorse umane
  • Impostazione della gerarchia dei rapporti, ecc.

Gestione del progetto

  • Definizione e impostazione dell'ambito del progetto
  • Gestione delle attività di project management
  • Monitoraggio dei progressi e delle prestazioni
  • Analisi dei rischi in ogni fase
  • Adotta le misure necessarie per evitare o risolvere i problemi
  • Agire come portavoce del progetto

Attività di gestione del software

La gestione dei progetti software comprende una serie di attività, che includono la pianificazione del progetto, la decisione dell'ambito del prodotto software, la stima dei costi in vari termini, la pianificazione di attività ed eventi e la gestione delle risorse. Le attività di gestione del progetto possono includere:

  • Project Planning
  • Scope Management
  • Project Estimation

Pianificazione del progetto

La pianificazione del progetto software è un compito, che viene eseguito prima che la produzione del software inizi effettivamente. Esiste per la produzione del software ma non comporta alcuna attività concreta che abbia alcun collegamento di direzione con la produzione del software; piuttosto è un insieme di più processi, che facilita la produzione di software. La pianificazione del progetto può includere quanto segue:

Gestione dell'ambito

Definisce lo scopo del progetto; questo include tutte le attività, il processo deve essere eseguito per realizzare un prodotto software consegnabile. La gestione dell'ambito è essenziale perché crea i confini del progetto definendo chiaramente cosa sarebbe stato fatto nel progetto e cosa non sarebbe stato fatto. Questo fa sì che il progetto contenga attività limitate e quantificabili, che possono essere facilmente documentate e, a sua volta, evita il superamento di costi e tempi.

Durante la gestione dell'ambito del progetto, è necessario:

  • Definisci l'ambito
  • Decidi la sua verifica e controllo
  • Dividi il progetto in varie parti più piccole per facilità di gestione.
  • Verifica l'ambito
  • Controllare l'ambito incorporando le modifiche all'ambito

Stima del progetto

Per una gestione efficace è necessaria una stima accurata delle varie misure. Con una stima corretta, i manager possono gestire e controllare il progetto in modo più efficiente ed efficace.

La stima del progetto può comportare quanto segue:

  • Software size estimation

    La dimensione del software può essere stimata in termini di KLOC (Kilo Line of Code) o calcolando il numero di punti funzione nel software. Le righe di codice dipendono dalle pratiche di codifica e i punti funzione variano a seconda dell'utente o dei requisiti software.

  • Effort estimation

    I responsabili stimano gli sforzi in termini di fabbisogno di personale e ore di lavoro necessarie per produrre il software. Per la stima dello sforzo, è necessario conoscere le dimensioni del software. Questo può essere derivato dall'esperienza dei manager, dai dati storici dell'organizzazione o dalle dimensioni del software possono essere convertite in sforzi utilizzando alcune formule standard.

  • Time estimation

    Dopo aver stimato le dimensioni e gli sforzi, è possibile stimare il tempo necessario per produrre il software. Gli sforzi richiesti sono suddivisi in sottocategorie secondo le specifiche dei requisiti e l'interdipendenza dei vari componenti del software. Le attività del software sono suddivise in attività, attività o eventi più piccoli in base a Work Breakthrough Structure (WBS). Le attività vengono pianificate su base giornaliera o in mesi di calendario.

    La somma del tempo richiesto per completare tutte le attività in ore o giorni è il tempo totale investito per completare il progetto.

  • Cost estimation

    Questo potrebbe essere considerato come il più difficile di tutti perché dipende da più elementi rispetto ai precedenti. Per stimare il costo del progetto, è necessario considerare:

    • Dimensioni del software
    • Qualità del software
    • Hardware
    • Software o strumenti aggiuntivi, licenze ecc.
    • Personale qualificato con competenze specifiche per l'attività
    • Viaggio coinvolto
    • Communication
    • Formazione e supporto

Tecniche di stima del progetto

Abbiamo discusso vari parametri che coinvolgono la stima del progetto come dimensioni, impegno, tempo e costo.

Il project manager può stimare i fattori elencati utilizzando due tecniche ampiamente riconosciute:

Tecnica di decomposizione

Questa tecnica assume il software come un prodotto di varie composizioni.

Esistono due modelli principali:

  • Line of Code La stima viene eseguita per conto del numero di righe di codici nel prodotto software.
  • Function Points La stima viene eseguita per conto del numero di punti funzione nel prodotto software.

Tecnica di stima empirica

Questa tecnica utilizza formule derivate empiricamente per effettuare la stima. Queste formule sono basate su LOC o FP.

  • Putnam Model

    Questo modello è realizzato da Lawrence H. Putnam, che si basa sulla distribuzione di frequenza di Norden (curva di Rayleigh). Il modello Putnam mappa il tempo e gli sforzi richiesti con le dimensioni del software.

  • COCOMO

    COCOMO sta per COnstructive COst MOdel, sviluppato da Barry W. Boehm. Divide il prodotto software in tre categorie di software: organico, semi-indipendente e incorporato.

Pianificazione del progetto

La pianificazione del progetto in un progetto si riferisce alla tabella di marcia di tutte le attività da svolgere con un ordine specificato ed entro la fascia oraria assegnata a ciascuna attività. I project manager tendono a definire varie attività e pietre miliari del progetto e organizzarle tenendo a mente vari fattori. Cercano compiti che si trovano in un percorso critico nella pianificazione, che sono necessari per completare in modo specifico (a causa dell'interdipendenza dei compiti) e rigorosamente entro il tempo assegnato. È meno probabile che la disposizione delle attività che si trova fuori dal percorso critico abbia un impatto su tutta la pianificazione del progetto.

Per programmare un progetto è necessario:

  • Suddividi le attività del progetto in una forma più piccola e gestibile
  • Scopri vari compiti e correlali
  • Stima il periodo di tempo richiesto per ogni attività
  • Dividi il tempo in unità di lavoro
  • Assegna un numero adeguato di unità di lavoro per ciascuna attività
  • Calcola il tempo totale richiesto per il progetto dall'inizio alla fine

Gestione delle risorse

Tutti gli elementi utilizzati per sviluppare un prodotto software possono essere considerati risorse per quel progetto. Ciò può includere risorse umane, strumenti produttivi e librerie software.

Le risorse sono disponibili in quantità limitata e rimangono nell'organizzazione come un pool di risorse. La carenza di risorse ostacola lo sviluppo del progetto e può essere in ritardo rispetto alla pianificazione. L'assegnazione di risorse extra aumenta i costi di sviluppo alla fine. È quindi necessario stimare e allocare risorse adeguate per il progetto.

La gestione delle risorse include:

  • Definizione di un progetto organizzativo corretto creando un team di progetto e assegnando le responsabilità a ciascun membro del team
  • Determinazione delle risorse richieste in una fase particolare e della loro disponibilità
  • Gestisci le risorse generando richieste di risorse quando sono necessarie e disallocandole quando non sono più necessarie.

Gestione del rischio di progetto

La gestione del rischio coinvolge tutte le attività relative all'identificazione, analisi e previsione di rischi prevedibili e non prevedibili nel progetto. Il rischio può includere quanto segue:

  • Personale esperto che lascia il progetto e nuovo personale in arrivo.
  • Cambiamento nella gestione organizzativa.
  • Modifica del requisito o interpretazione errata del requisito.
  • Sottovalutazione del tempo e delle risorse richieste.
  • Cambiamenti tecnologici, cambiamenti ambientali, concorrenza tra le imprese.

Processo di gestione del rischio

Ci sono le seguenti attività coinvolte nel processo di gestione del rischio:

  • Identification - Prendere nota di tutti i possibili rischi che possono verificarsi nel progetto.
  • Categorize - Classificare i rischi noti in intensità di rischio alta, media e bassa in base al loro possibile impatto sul progetto.
  • Manage - Analizza la probabilità di accadimento dei rischi nelle varie fasi. Pianifica per evitare o affrontare i rischi. Tenta di ridurre al minimo i loro effetti collaterali.
  • Monitor - Monitorare attentamente i potenziali rischi e i loro primi sintomi. Monitorare anche gli effetti delle misure adottate per mitigarli o evitarli.

Esecuzione e monitoraggio del progetto

In questa fase, le attività descritte nei piani di progetto vengono eseguite secondo i loro programmi.

L'esecuzione necessita di monitoraggio per verificare se tutto sta andando secondo il piano. Il monitoraggio consiste nell'osservare per verificare la probabilità di rischio e adottare misure per affrontare il rischio o segnalare lo stato di varie attività.

Queste misure includono:

  • Activity Monitoring - Tutte le attività pianificate all'interno di alcune attività possono essere monitorate su base giornaliera. Quando tutte le attività in un'attività sono state completate, viene considerata completa.
  • Status Reports - I rapporti contengono lo stato delle attività e dei compiti completati entro un determinato periodo di tempo, generalmente una settimana. Lo stato può essere contrassegnato come finito, in sospeso o in lavorazione, ecc.
  • Milestones Checklist - Ogni progetto è suddiviso in più fasi in cui vengono eseguite le attività principali (pietre miliari) in base alle fasi di SDLC. Questa lista di controllo delle pietre miliari viene preparata una volta ogni poche settimane e riporta lo stato delle tappe.

Gestione della comunicazione del progetto

Una comunicazione efficace gioca un ruolo fondamentale nel successo di un progetto. Colma le lacune tra il cliente e l'organizzazione, tra i membri del team e altre parti interessate nel progetto come i fornitori di hardware.

La comunicazione può essere orale o scritta. Il processo di gestione della comunicazione può avere i seguenti passaggi:

  • Planning - Questa fase include l'identificazione di tutti gli stakeholder del progetto e le modalità di comunicazione tra di loro. Considera inoltre se sono necessarie ulteriori strutture di comunicazione.
  • Sharing - Dopo aver determinato i vari aspetti della pianificazione, il manager si concentra sulla condivisione delle informazioni corrette con la persona corretta al momento giusto. Ciò mantiene tutti i soggetti coinvolti nel progetto aggiornati con l'avanzamento del progetto e il suo stato.
  • Feedback - I project manager utilizzano varie misure e meccanismi di feedback e creano rapporti sullo stato e sulle prestazioni. Questo meccanismo garantisce che l'input dei vari stakeholder arrivi al project manager come feedback.
  • Closure - Alla fine di ogni evento importante, alla fine di una fase di SDLC o alla fine del progetto stesso, viene formalmente annunciata la chiusura amministrativa per aggiornare ogni stakeholder mediante invio di e-mail, distribuzione di una copia cartacea del documento o altro mezzo di comunicazione efficace.

Dopo la chiusura, il team passa alla fase o al progetto successivo.

Gestione della configurazione

La gestione della configurazione è un processo di tracciamento e controllo delle modifiche nel software in termini di requisiti, design, funzioni e sviluppo del prodotto.

IEEE lo definisce come "il processo di identificazione e definizione degli articoli nel sistema, controllo del cambiamento di questi articoli durante il loro ciclo di vita, registrazione e segnalazione dello stato degli articoli e delle richieste di modifica e verifica della completezza e correttezza degli articoli".

In genere, una volta finalizzato l'SRS, ci sono meno possibilità di richiedere modifiche da parte dell'utente. Se si verificano, le modifiche vengono affrontate solo previa approvazione della dirigenza superiore, in quanto esiste la possibilità di un superamento dei costi e dei tempi.

Baseline

Si presume una fase di SDLC se è di base, ovvero la linea di base è una misurazione che definisce la completezza di una fase. Una fase è fondamentale quando tutte le attività ad essa relative sono terminate e ben documentate. Se non fosse la fase finale, il suo output verrebbe utilizzato nella successiva fase immediata.

La gestione della configurazione è una disciplina dell'amministrazione dell'organizzazione, che si prende cura del verificarsi di qualsiasi cambiamento (processo, requisito, tecnologico, strategico, ecc.) Dopo che una fase è fondamentale. CM tiene sotto controllo eventuali modifiche apportate al software.

Controllo delle modifiche

Il controllo delle modifiche è una funzione della gestione della configurazione, che garantisce che tutte le modifiche apportate al sistema software siano coerenti e effettuate secondo le regole e le normative dell'organizzazione.

Una modifica nella configurazione del prodotto passa attraverso i seguenti passaggi:

  • Identification- Una richiesta di modifica arriva da una fonte interna o esterna. Quando la richiesta di modifica viene identificata formalmente, viene adeguatamente documentata.

  • Validation - Viene verificata la validità della richiesta di modifica e viene confermata la sua procedura di trattamento.

  • Analysis- L'impatto della richiesta di modifica viene analizzato in termini di pianificazione, costi e sforzi richiesti. Viene analizzato l'impatto complessivo del cambiamento prospettico sul sistema.

  • Control- Se la modifica prospettica ha un impatto su troppe entità nel sistema o è inevitabile, è obbligatorio ottenere l'approvazione delle alte autorità prima che la modifica sia incorporata nel sistema. Si decide se vale la pena incorporare il cambiamento o meno. In caso contrario, la richiesta di modifica viene rifiutata formalmente.

  • Execution - Se la fase precedente determina di eseguire la richiesta di modifica, questa fase intraprende le azioni appropriate per eseguire la modifica, effettua una revisione approfondita se necessario.

  • Close request- La modifica viene verificata per la corretta implementazione e fusione con il resto del sistema. Questa nuova modifica incorporata nel software è documentata adeguatamente e la richiesta viene formalmente chiusa.

Strumenti di gestione del progetto

Il rischio e l'incertezza si moltiplicano rispetto alla dimensione del progetto, anche quando il progetto è sviluppato secondo metodologie prestabilite.

Sono disponibili strumenti che aiutano a una gestione efficace del progetto. Alcuni sono descritti -

Diagramma di Gantt

I diagrammi di Gantt sono stati ideati da Henry Gantt (1917). Rappresenta la pianificazione del progetto rispetto ai periodi di tempo. È un grafico a barre orizzontali con barre che rappresentano le attività e il tempo programmato per le attività del progetto.

Grafico PERT

Il grafico PERT (Program Evaluation & Review Technique) è uno strumento che rappresenta il progetto come diagramma di rete. È in grado di rappresentare graficamente gli eventi principali del progetto sia in modo parallelo che consecutivo. Gli eventi, che si verificano uno dopo l'altro, mostrano la dipendenza dell'evento successivo rispetto a quello precedente.

Gli eventi vengono visualizzati come nodi numerati. Sono collegati da frecce etichettate che raffigurano la sequenza di attività nel progetto.

Istogramma delle risorse

Si tratta di uno strumento grafico che contiene una barra o un grafico che rappresenta il numero di risorse (solitamente personale qualificato) necessarie nel tempo per un evento (o fase) del progetto. L'istogramma delle risorse è uno strumento efficace per la pianificazione e il coordinamento del personale.

Analisi del percorso critico

Questi strumenti sono utili per riconoscere attività interdipendenti nel progetto. Aiuta anche a scoprire il percorso più breve o il percorso critico per completare con successo il progetto. Come il diagramma PERT, a ogni evento viene assegnato un periodo di tempo specifico. Questo strumento mostra la dipendenza dell'evento assumendo che un evento possa procedere al successivo solo se quello precedente è stato completato.

Gli eventi vengono organizzati in base alla loro prima ora di inizio possibile. Il percorso tra il nodo iniziale e quello finale è un percorso critico che non può essere ulteriormente ridotto e tutti gli eventi devono essere eseguiti nello stesso ordine.

I requisiti software sono la descrizione delle caratteristiche e delle funzionalità del sistema di destinazione. I requisiti trasmettono le aspettative degli utenti dal prodotto software. I requisiti possono essere evidenti o nascosti, noti o sconosciuti, previsti o inattesi dal punto di vista del cliente.

Ingegneria dei requisiti

Il processo per raccogliere i requisiti software dal cliente, analizzarli e documentarli è noto come ingegneria dei requisiti.

L'obiettivo dell'ingegneria dei requisiti è sviluppare e mantenere un documento "Specifiche dei requisiti di sistema" sofisticato e descrittivo.

Processo di ingegneria dei requisiti

È un processo in quattro fasi, che include:

  • Studio di fattibilità
  • Raccolta dei requisiti
  • Specifiche dei requisiti software
  • Convalida dei requisiti software

Vediamo brevemente il processo:

Studio di fattibilità

Quando il cliente si rivolge all'organizzazione per ottenere lo sviluppo del prodotto desiderato, gli viene in mente un'idea approssimativa di quali funzioni devono eseguire il software e quali tutte le funzionalità sono previste dal software.

Facendo riferimento a queste informazioni, gli analisti effettuano uno studio dettagliato sulla possibilità di sviluppare il sistema desiderato e le sue funzionalità.

Questo studio di fattibilità è focalizzato verso l'obiettivo dell'organizzazione. Questo studio analizza se il prodotto software può essere materializzato praticamente in termini di implementazione, contributo del progetto all'organizzazione, vincoli di costo e secondo i valori e gli obiettivi dell'organizzazione. Esplora gli aspetti tecnici del progetto e del prodotto come usabilità, manutenibilità, produttività e capacità di integrazione.

Il risultato di questa fase dovrebbe essere un rapporto sullo studio di fattibilità che dovrebbe contenere commenti e raccomandazioni adeguati per la direzione sull'opportunità o meno di intraprendere il progetto.

Raccolta dei requisiti

Se il rapporto di fattibilità è positivo per intraprendere il progetto, la fase successiva inizia con la raccolta dei requisiti da parte dell'utente. Analisti e ingegneri comunicano con il cliente e gli utenti finali per conoscere le loro idee su ciò che il software dovrebbe fornire e quali funzionalità desiderano che il software includa.

Specifiche dei requisiti software

SRS è un documento creato dall'analista di sistema dopo che i requisiti sono stati raccolti da varie parti interessate.

SRS definisce il modo in cui il software previsto interagirà con l'hardware, le interfacce esterne, la velocità di funzionamento, il tempo di risposta del sistema, la portabilità del software su varie piattaforme, la manutenibilità, la velocità di ripristino dopo l'arresto anomalo, la sicurezza, la qualità, i limiti ecc.

I requisiti ricevuti dal cliente sono scritti in linguaggio naturale. È responsabilità dell'analista di sistema documentare i requisiti in linguaggio tecnico in modo che possano essere compresi e utili dal team di sviluppo software.

SRS dovrebbe fornire le seguenti funzionalità:

  • I requisiti dell'utente sono espressi in linguaggio naturale.
  • I requisiti tecnici sono espressi in un linguaggio strutturato, utilizzato all'interno dell'organizzazione.
  • La descrizione del progetto dovrebbe essere scritta in pseudo codice.
  • Formato dei moduli e delle schermate della GUI.
  • Notazioni condizionali e matematiche per DFD ecc.

Convalida dei requisiti software

Dopo che le specifiche dei requisiti sono state sviluppate, i requisiti menzionati in questo documento vengono convalidati. L'utente potrebbe richiedere una soluzione illegale e poco pratica o gli esperti potrebbero interpretare i requisiti in modo errato. Ciò si traduce in un enorme aumento dei costi se non viene stroncato sul nascere. I requisiti possono essere verificati rispetto alle seguenti condizioni:

  • Se possono essere praticamente implementati
  • Se sono validi e secondo funzionalità e dominio del software
  • Se ci sono ambiguità
  • Se sono completi
  • Se possono essere dimostrati

Processo di Elicitazione dei Requisiti

Il processo di elicitazione dei requisiti può essere rappresentato utilizzando il seguente diagramma:

  • Requirements gathering - Gli sviluppatori discutono con il cliente e gli utenti finali e conoscono le loro aspettative dal software.
  • Organizing Requirements - Gli sviluppatori danno la priorità e organizzano i requisiti in ordine di importanza, urgenza e convenienza.
  • Negotiation & discussion - Se i requisiti sono ambigui o ci sono dei conflitti nei requisiti dei vari stakeholder, se lo sono, viene negoziato e discusso con gli stakeholder. I requisiti possono quindi essere prioritari e ragionevolmente compromessi.

    I requisiti provengono da diversi stakeholder. Per rimuovere ambiguità e conflitti, vengono discussi per chiarezza e correttezza. Requisiti irrealistici sono ragionevolmente compromessi.

  • Documentation - Tutti i requisiti formali e informali, funzionali e non funzionali sono documentati e resi disponibili per l'elaborazione della fase successiva.

Tecniche di sollecitazione dei requisiti

Requirements Elicitation è il processo per scoprire i requisiti per un sistema software previsto comunicando con il cliente, gli utenti finali, gli utenti del sistema e altri che hanno un interesse nello sviluppo del sistema software.

Esistono vari modi per scoprire i requisiti

Interviste

Le interviste sono un mezzo forte per raccogliere i requisiti. L'organizzazione può condurre diversi tipi di interviste come:

  • Interviste strutturate (chiuse), dove ogni singola informazione da raccogliere viene decisa in anticipo, seguono con fermezza gli schemi e gli argomenti di discussione.
  • Interviste non strutturate (aperte), in cui le informazioni da raccogliere non sono decise in anticipo, più flessibili e meno distorte.
  • Colloqui orali
  • Interviste scritte
  • Colloqui individuali che si tengono tra due persone sul tavolo.
  • Colloqui di gruppo che si svolgono tra gruppi di partecipanti. Aiutano a scoprire qualsiasi requisito mancante poiché sono coinvolte numerose persone.

Sondaggi

L'organizzazione può condurre sondaggi tra le varie parti interessate interrogando le loro aspettative e requisiti dal sistema imminente.

Questionari

Un documento con una serie predefinita di domande oggettive e le rispettive opzioni viene consegnato a tutti gli stakeholder per rispondere, che vengono raccolti e compilati.

Un difetto di questa tecnica è che, se un'opzione per qualche problema non è menzionata nel questionario, il problema potrebbe essere lasciato incustodito.

Analisi dei compiti

Un team di ingegneri e sviluppatori può analizzare l'operazione per la quale è richiesto il nuovo sistema. Se il cliente ha già del software per eseguire determinate operazioni, viene studiato e vengono raccolti i requisiti del sistema proposto.

Analisi del dominio

Ogni software rientra in una categoria di dominio. Le persone esperte nel dominio possono essere di grande aiuto per analizzare requisiti generali e specifici.

Brainstorming

Si tiene un dibattito informale tra i vari stakeholder e tutti i loro input vengono registrati per ulteriori analisi dei requisiti.

Prototipazione

La prototipazione sta costruendo un'interfaccia utente senza aggiungere funzionalità di dettaglio per consentire all'utente di interpretare le caratteristiche del prodotto software previsto. Aiuta a dare un'idea migliore dei requisiti. Se non è installato alcun software presso il cliente per riferimento dello sviluppatore e il cliente non è a conoscenza dei propri requisiti, lo sviluppatore crea un prototipo basato sui requisiti inizialmente menzionati. Il prototipo viene mostrato al cliente e il feedback viene annotato. Il feedback del cliente serve come input per la raccolta dei requisiti.

Osservazione

Un team di esperti visita l'organizzazione o il luogo di lavoro del cliente. Osservano l'effettivo funzionamento degli impianti esistenti installati. Osservano il flusso di lavoro alla fine del cliente e come vengono affrontati i problemi di esecuzione. Il team stesso trae alcune conclusioni che aiutano a formare i requisiti attesi dal software.

Caratteristiche dei requisiti software

La raccolta dei requisiti software è la base dell'intero progetto di sviluppo software. Quindi devono essere chiari, corretti e ben definiti.

Una specifica completa dei requisiti software deve essere:

  • Clear
  • Correct
  • Consistent
  • Coherent
  • Comprehensible
  • Modifiable
  • Verifiable
  • Prioritized
  • Unambiguous
  • Traceable
  • Fonte credibile

Requisiti software

Dovremmo cercare di capire che tipo di requisiti possono sorgere nella fase di elaborazione dei requisiti e quali tipi di requisiti sono previsti dal sistema software.

In generale, i requisiti software dovrebbero essere classificati in due categorie:

Richieste funzionali

I requisiti relativi all'aspetto funzionale del software rientrano in questa categoria.

Definiscono funzioni e funzionalità all'interno e dal sistema software.

Esempi -

  • Opzione di ricerca data all'utente per cercare da varie fatture.
  • L'utente dovrebbe essere in grado di inviare qualsiasi rapporto alla direzione.
  • Gli utenti possono essere divisi in gruppi e ai gruppi possono essere assegnati diritti separati.
  • Dovrebbe rispettare le regole aziendali e le funzioni amministrative.
  • Il software viene sviluppato mantenendo intatta la compatibilità verso il basso.

Requisiti non funzionali

I requisiti, che non sono correlati all'aspetto funzionale del software, rientrano in questa categoria. Sono caratteristiche implicite o previste del software, che gli utenti presumono.

I requisiti non funzionali includono:

  • Security
  • Logging
  • Storage
  • Configuration
  • Performance
  • Cost
  • Interoperability
  • Flexibility
  • Ripristino di emergenza
  • Accessibility

I requisiti sono classificati logicamente come

  • Must Have : Il software non può essere considerato operativo senza di loro.
  • Should have : Miglioramento della funzionalità del software.
  • Could have : Il software può ancora funzionare correttamente con questi requisiti.
  • Wish list : Questi requisiti non sono associati ad alcun obiettivo del software.

Durante lo sviluppo del software, "Must have" deve essere implementato, "Should have" è oggetto di dibattito con le parti interessate e negazione, mentre "could have" e "wish list" possono essere conservati per gli aggiornamenti software.

Requisiti dell'interfaccia utente

L'interfaccia utente è una parte importante di qualsiasi software, hardware o sistema ibrido. Un software è ampiamente accettato se è:

  • facile da usare
  • veloce in risposta
  • gestire efficacemente gli errori operativi
  • fornendo un'interfaccia utente semplice ma coerente

L'accettazione da parte dell'utente dipende principalmente da come l'utente può utilizzare il software. L'interfaccia utente è l'unico modo per gli utenti di percepire il sistema. Un sistema software ben funzionante deve inoltre essere dotato di un'interfaccia utente attraente, chiara, coerente e reattiva. In caso contrario, le funzionalità del sistema software non possono essere utilizzate in modo conveniente. Si dice che un sistema sia buono se fornisce i mezzi per usarlo in modo efficiente. I requisiti dell'interfaccia utente sono brevemente menzionati di seguito:

  • Presentazione dei contenuti
  • Navigazione facile
  • Interfaccia semplice
  • Responsive
  • Elementi dell'interfaccia utente coerenti
  • Meccanismo di feedback
  • Impostazioni predefinite
  • Layout mirato
  • Uso strategico del colore e della consistenza.
  • Fornisci informazioni di aiuto
  • Approccio incentrato sull'utente
  • Impostazioni di visualizzazione basate sul gruppo.

Analista di sistema software

L'analista di sistema in un'organizzazione IT è una persona che analizza i requisiti del sistema proposto e garantisce che i requisiti siano concepiti e documentati adeguatamente e correttamente. Il ruolo di un analista inizia durante la fase di analisi del software di SDLC. È responsabilità dell'analista assicurarsi che il software sviluppato soddisfi i requisiti del cliente.

Gli analisti di sistema hanno le seguenti responsabilità:

  • Analisi e comprensione dei requisiti del software previsto
  • Capire come il progetto contribuirà agli obiettivi dell'organizzazione
  • Identifica le fonti del fabbisogno
  • Convalida del requisito
  • Sviluppare e implementare un piano di gestione dei requisiti
  • Documentazione dei requisiti aziendali, tecnici, di processo e di prodotto
  • Coordinamento con i clienti per dare priorità ai requisiti e rimuovere e ambiguità
  • Finalizzare i criteri di accettazione con il cliente e altri stakeholder

Metriche e misure del software

Le misure software possono essere intese come un processo di quantificazione e simbolizzazione di vari attributi e aspetti del software.

Le metriche software forniscono misure per vari aspetti del processo software e del prodotto software.

Le misure del software sono un requisito fondamentale dell'ingegneria del software. Non solo aiutano a controllare il processo di sviluppo del software, ma aiutano anche a mantenere eccellente la qualità del prodotto finale.

Secondo Tom DeMarco, un (ingegnere del software), "Non puoi controllare ciò che non puoi misurare". Dal suo detto, è molto chiaro quanto siano importanti le misure del software.

Vediamo alcune metriche del software:

  • Size Metrics - LOC (righe di codice), per lo più calcolate in migliaia di righe di codice sorgente fornite, denotate come KLOC.

    Function Point Count è la misura della funzionalità fornita dal software. Il conteggio dei punti funzione definisce la dimensione dell'aspetto funzionale del software.

  • Complexity Metrics - La complessità ciclomatica di McCabe quantifica il limite superiore del numero di percorsi indipendenti in un programma, che è percepito come complessità del programma o dei suoi moduli. È rappresentato in termini di concetti di teoria dei grafi utilizzando il grafico del flusso di controllo.
  • Quality Metrics - I difetti, i loro tipi e cause, le conseguenze, l'intensità della gravità e le loro implicazioni definiscono la qualità del prodotto.

    Il numero di difetti riscontrati nel processo di sviluppo e il numero di difetti segnalati dal cliente dopo che il prodotto è stato installato o consegnato presso il cliente definiscono la qualità del prodotto.

  • Process Metrics - In varie fasi dell'SDLC, i metodi e gli strumenti utilizzati, gli standard aziendali e le prestazioni di sviluppo sono metriche di processo del software.
  • Resource Metrics - L'impegno, il tempo e le varie risorse utilizzate rappresentano le metriche per la misurazione delle risorse.

La progettazione del software è un processo per trasformare i requisiti dell'utente in una forma adeguata, che aiuta il programmatore nella codifica e nell'implementazione del software.

Per la valutazione dei requisiti dell'utente, viene creato un documento SRS (Software Requirement Specification) mentre per la codifica e l'implementazione, sono necessari requisiti più specifici e dettagliati in termini di software. L'output di questo processo può essere utilizzato direttamente nell'implementazione nei linguaggi di programmazione.

La progettazione del software è il primo passo in SDLC (Software Design Life Cycle), che sposta la concentrazione dal dominio del problema al dominio della soluzione. Cerca di specificare come soddisfare i requisiti menzionati in SRS.

Livelli di progettazione del software

La progettazione del software produce tre livelli di risultati:

  • Architectural Design - Il progetto architettonico è la più alta versione astratta del sistema. Identifica il software come un sistema con molti componenti che interagiscono tra loro. A questo livello, i progettisti ottengono l'idea del dominio della soluzione proposta.
  • High-level Design- Il design di alto livello rompe il concetto di "singola entità-componente multiplo" del design architettonico in una visione meno astratta di sottosistemi e moduli e descrive la loro interazione reciproca. La progettazione di alto livello si concentra su come il sistema e tutti i suoi componenti possono essere implementati in forme di moduli. Riconosce la struttura modulare di ogni sottosistema e la loro relazione e interazione tra loro.
  • Detailed Design- La progettazione dettagliata si occupa della parte di implementazione di ciò che è visto come un sistema e dei suoi sottosistemi nei due progetti precedenti. È più dettagliato verso i moduli e le loro implementazioni. Definisce la struttura logica di ogni modulo e le loro interfacce per comunicare con altri moduli.

Modularizzazione

La modularizzazione è una tecnica per dividere un sistema software in più moduli discreti e indipendenti, che dovrebbero essere in grado di svolgere attività in modo indipendente. Questi moduli possono funzionare come costrutti di base per l'intero software. I progettisti tendono a progettare moduli in modo che possano essere eseguiti e / o compilati separatamente e indipendentemente.

Il design modulare segue involontariamente le regole della strategia di risoluzione dei problemi "divide et impera", questo perché ci sono molti altri vantaggi associati al design modulare di un software.

Vantaggio della modularizzazione:

  • I componenti più piccoli sono più facili da mantenere
  • Il programma può essere suddiviso in base agli aspetti funzionali
  • Il livello di astrazione desiderato può essere portato nel programma
  • I componenti con elevata coesione possono essere riutilizzati
  • È possibile rendere possibile l'esecuzione simultanea
  • Desiderato dall'aspetto della sicurezza

Concorrenza

Indietro nel tempo, tutto il software deve essere eseguito in sequenza. Per esecuzione sequenziale si intende che le istruzioni codificate verranno eseguite una dopo l'altra, il che implica che solo una parte del programma viene attivata in un dato momento. Ad esempio, un software ha più moduli, quindi solo uno di tutti i moduli può essere trovato attivo in qualsiasi momento dell'esecuzione.

Nella progettazione del software, la concorrenza viene implementata suddividendo il software in più unità di esecuzione indipendenti, come i moduli, ed eseguendole in parallelo. In altre parole, la concorrenza fornisce al software la capacità di eseguire più di una parte di codice in parallelo tra loro.

È necessario che i programmatori e i progettisti riconoscano quei moduli, che possono essere eseguiti in parallelo.

Esempio

La funzione di controllo ortografico nell'elaboratore di testi è un modulo del software, che funziona a fianco dell'elaboratore di testi stesso.

Accoppiamento e coesione

Quando un programma software è modularizzato, i suoi compiti sono suddivisi in più moduli in base ad alcune caratteristiche. Come sappiamo, i moduli sono un insieme di istruzioni messe insieme per eseguire alcuni compiti. Tuttavia, sono considerati come entità singole ma possono fare riferimento l'uno all'altro per lavorare insieme. Ci sono misure attraverso le quali è possibile misurare la qualità di un progetto di moduli e la loro interazione tra di loro. Queste misure sono chiamate accoppiamento e coesione.

Coesione

La coesione è una misura che definisce il grado di intra-affidabilità all'interno degli elementi di un modulo. Maggiore è la coesione, migliore è la struttura del programma.

Esistono sette tipi di coesione, vale a dire:

  • Co-incidental cohesion -È una coesione casuale e non pianificata, che potrebbe essere il risultato della suddivisione del programma in moduli più piccoli per motivi di modularizzazione. Poiché non è pianificato, può creare confusione ai programmatori e generalmente non è accettato.
  • Logical cohesion - Quando gli elementi categorizzati logicamente vengono messi insieme in un modulo, si parla di coesione logica.
  • emporal Cohesion - Quando gli elementi del modulo sono organizzati in modo tale da essere elaborati in un momento simile nel tempo, si parla di coesione temporale.
  • Procedural cohesion - Quando gli elementi del modulo sono raggruppati insieme, che vengono eseguiti in sequenza per eseguire un'attività, si parla di coesione procedurale.
  • Communicational cohesion - Quando gli elementi del modulo sono raggruppati insieme, che vengono eseguiti in sequenza e lavorano sugli stessi dati (informazioni), si parla di coesione comunicativa.
  • Sequential cohesion - Quando gli elementi del modulo sono raggruppati perché l'output di un elemento funge da input per un altro e così via, si parla di coesione sequenziale.
  • Functional cohesion - È considerato il più alto grado di coesione ed è altamente previsto. Gli elementi del modulo in coesione funzionale sono raggruppati perché contribuiscono tutti a un'unica funzione ben definita. Può anche essere riutilizzato.

Accoppiamento

L'accoppiamento è una misura che definisce il livello di interdipendenza tra i moduli di un programma. Indica a quale livello i moduli interferiscono e interagiscono tra loro. Più basso è l'accoppiamento, migliore è il programma.

Esistono cinque livelli di accoppiamento, vale a dire:

  • Content coupling - Quando un modulo può accedere direttamente o modificare o fare riferimento al contenuto di un altro modulo, si parla di accoppiamento a livello di contenuto.
  • Common coupling- Quando più moduli hanno accesso in lettura e scrittura ad alcuni dati globali, si parla di accoppiamento comune o globale.
  • Control coupling- Due moduli sono chiamati accoppiati al controllo se uno di essi decide la funzione dell'altro modulo o ne modifica il flusso di esecuzione.
  • Stamp coupling- Quando più moduli condividono una struttura dati comune e lavorano su parti diverse di essa, si parla di accoppiamento timbro.
  • Data coupling- L'accoppiamento dei dati avviene quando due moduli interagiscono tra loro tramite il passaggio di dati (come parametro). Se un modulo passa la struttura dei dati come parametro, il modulo ricevente dovrebbe utilizzare tutti i suoi componenti.

Idealmente, nessun accoppiamento è considerato il migliore.

Verifica del progetto

L'output del processo di progettazione del software è la documentazione di progettazione, pseudo codici, diagrammi logici dettagliati, diagrammi di processo e descrizione dettagliata di tutti i requisiti funzionali o non funzionali.

La fase successiva, che è l'implementazione del software, dipende da tutti gli output sopra menzionati.

Diventa quindi necessario verificare l'uscita prima di procedere alla fase successiva. Prima viene rilevato un errore, meglio è o potrebbe non essere rilevato fino al test del prodotto. Se gli output della fase di progettazione sono in forma di notazione formale, è necessario utilizzare i relativi strumenti di verifica associati, altrimenti è possibile utilizzare una revisione approfondita del progetto per la verifica e la convalida.

Con un approccio di verifica strutturato, i revisori possono rilevare i difetti che potrebbero essere causati trascurando alcune condizioni. Una buona revisione del progetto è importante per una buona progettazione, accuratezza e qualità del software.

L'analisi e la progettazione del software includono tutte le attività che aiutano a trasformare la specifica dei requisiti in implementazione. Le specifiche dei requisiti specificano tutte le aspettative funzionali e non funzionali dal software. Queste specifiche dei requisiti si presentano sotto forma di documenti leggibili e comprensibili, a cui un computer non ha nulla a che fare.

L'analisi e la progettazione del software è la fase intermedia, che aiuta a trasformare i requisiti leggibili dall'uomo in codice reale.

Vediamo alcuni strumenti di analisi e progettazione utilizzati dai progettisti di software:

Diagramma del flusso di dati

Il diagramma del flusso di dati è una rappresentazione grafica del flusso di dati in un sistema informativo. È in grado di rappresentare il flusso di dati in entrata, il flusso di dati in uscita e i dati memorizzati. Il DFD non menziona nulla sul modo in cui i dati fluiscono attraverso il sistema.

C'è una differenza evidente tra DFD e diagramma di flusso. Il diagramma di flusso rappresenta il flusso di controllo nei moduli del programma. I DFD rappresentano il flusso di dati nel sistema a vari livelli. DFD non contiene alcun controllo o elemento di diramazione.

Tipi di DFD

I diagrammi del flusso di dati sono logici o fisici.

  • Logical DFD - Questo tipo di DFD si concentra sul processo di sistema e sul flusso di dati nel sistema, ad esempio in un sistema software bancario, il modo in cui i dati vengono spostati tra entità diverse.
  • Physical DFD- Questo tipo di DFD mostra come il flusso di dati è effettivamente implementato nel sistema. È più specifico e vicino all'implementazione.

Componenti DFD

DFD può rappresentare l'origine, la destinazione, l'archiviazione e il flusso di dati utilizzando il seguente set di componenti:

  • Entities- Le entità sono l'origine e la destinazione dei dati informativi. Le entità sono rappresentate da rettangoli con i rispettivi nomi.
  • Process - Le attività e le azioni intraprese sui dati sono rappresentate da rettangoli circolari o con bordi arrotondati.
  • Data Storage - Esistono due varianti di archiviazione dei dati: può essere rappresentata come un rettangolo con l'assenza di entrambi i lati più piccoli o come un rettangolo aperto con un solo lato mancante.
  • Data Flow- Il movimento dei dati è indicato da frecce appuntite. Il movimento dei dati è mostrato dalla base della freccia come origine verso la punta della freccia come destinazione.

Livelli di DFD

  • Level 0- Il livello di astrazione più alto DFD è noto come DFD di livello 0, che rappresenta l'intero sistema informativo come un diagramma che nasconde tutti i dettagli sottostanti. I DFD di livello 0 sono noti anche come DFD a livello di contesto.
  • Level 1- Il DFD di livello 0 è suddiviso in DFD di livello 1 più specifico. Il DFD di livello 1 descrive i moduli di base nel sistema e il flusso di dati tra i vari moduli. Il DFD di livello 1 menziona anche i processi di base e le fonti di informazione.
  • Level 2 - A questo livello, DFD mostra come i dati fluiscono all'interno dei moduli menzionati nel Livello 1.

    I DFD di livello superiore possono essere trasformati in DFD di livello inferiore più specifici con un livello di comprensione più profondo a meno che non si raggiunga il livello di specifica desiderato.

Grafici di struttura

Il grafico della struttura è un grafico derivato dal diagramma del flusso di dati. Rappresenta il sistema in modo più dettagliato rispetto a DFD. Suddivide l'intero sistema in moduli funzionali più bassi, descrive le funzioni e le sottofunzioni di ciascun modulo del sistema con maggiore dettaglio rispetto a DFD.

Il grafico della struttura rappresenta la struttura gerarchica dei moduli. Ad ogni livello viene eseguita un'attività specifica.

Ecco i simboli utilizzati nella costruzione dei grafici della struttura:

  • Module- Rappresenta un processo, una subroutine o un'attività. Un modulo di controllo si dirama a più di un sottomodulo. I moduli libreria sono riutilizzabili e richiamabili da qualsiasi modulo.
  • Condition- È rappresentato da un piccolo diamante alla base del modulo. Descrive che il modulo di controllo può selezionare qualsiasi sottoprogramma in base a una condizione.
  • Jump - Viene mostrata una freccia che punta all'interno del modulo per indicare che il controllo salterà al centro del sottomodulo.
  • Loop- Una freccia curva rappresenta il loop nel modulo. Tutti i sottomoduli coperti dal loop ripetono l'esecuzione del modulo.
  • Data flow - Una freccia diretta con un cerchio vuoto all'estremità rappresenta il flusso di dati.
  • Control flow - Una freccia diretta con un cerchio pieno all'estremità rappresenta il flusso di controllo.

Diagramma HIPO

Il diagramma HIPO (Hierarchical Input Process Output) è una combinazione di due metodi organizzati per analizzare il sistema e fornire i mezzi di documentazione. Il modello HIPO è stato sviluppato da IBM nell'anno 1970.

Il diagramma HIPO rappresenta la gerarchia dei moduli nel sistema software. L'analista utilizza il diagramma HIPO per ottenere una visione di alto livello delle funzioni del sistema. Decompone le funzioni in sotto-funzioni in modo gerarchico. Raffigura le funzioni svolte dal sistema.

I diagrammi HIPO sono utili a scopo di documentazione. La loro rappresentazione grafica rende più facile per designer e manager avere un'idea pittorica della struttura del sistema.

A differenza del diagramma IPO (Input Process Output), che rappresenta il flusso di controllo e dati in un modulo, HIPO non fornisce alcuna informazione sul flusso di dati o sul flusso di controllo.

Esempio

Entrambe le parti del diagramma HIPO, la presentazione gerarchica e il grafico IPO vengono utilizzate per la progettazione della struttura del programma software e per la documentazione dello stesso.

Inglese strutturato

La maggior parte dei programmatori non è a conoscenza del quadro generale del software, quindi si affida solo a ciò che i loro manager dicono loro di fare. È responsabilità della gestione superiore del software fornire informazioni accurate ai programmatori per sviluppare codice accurato ma veloce.

Altre forme di metodi, che utilizzano grafici o diagrammi, possono talvolta essere interpretati in modo diverso da persone diverse.

Quindi, analisti e progettisti del software escogitano strumenti come l'inglese strutturato. Non è altro che la descrizione di ciò che è necessario per codificare e di come codificarlo. L'inglese strutturato aiuta il programmatore a scrivere codice senza errori.

Altre forme di metodi, che utilizzano grafici o diagrammi, possono talvolta essere interpretati in modo diverso da persone diverse. Qui, sia l'inglese strutturato che lo pseudo-codice cercano di mitigare questo divario di comprensione.

L'inglese strutturato è il Utilizza parole inglesi semplici nel paradigma di programmazione strutturata. Non è il codice definitivo, ma una sorta di descrizione di ciò che è necessario per codificare e di come codificarlo. Di seguito sono riportati alcuni segni di programmazione strutturata.

IF-THEN-ELSE,  
DO-WHILE-UNTIL

Analyst utilizza la stessa variabile e il nome dei dati, che sono memorizzati nel Dizionario dei dati, rendendo molto più semplice scrivere e comprendere il codice.

Esempio

Prendiamo lo stesso esempio di autenticazione del cliente nell'ambiente di acquisto online. Questa procedura per autenticare il cliente può essere scritta in inglese strutturato come:

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

Il codice scritto in inglese strutturato è più simile all'inglese parlato quotidianamente. Non può essere implementato direttamente come codice di software. L'inglese strutturato è indipendente dal linguaggio di programmazione.

Pseudo-codice

Lo pseudo codice è scritto più vicino al linguaggio di programmazione. Può essere considerato un linguaggio di programmazione aumentato, pieno di commenti e descrizioni.

Lo pseudo codice evita la dichiarazione delle variabili ma vengono scritti utilizzando alcuni costrutti del linguaggio di programmazione reale, come C, Fortran, Pascal ecc.

Lo pseudo codice contiene più dettagli di programmazione rispetto all'inglese strutturato. Fornisce un metodo per eseguire l'attività, come se un computer stesse eseguendo il codice.

Esempio

Programma per stampare Fibonacci fino a n numeri.

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;
   }
}

Tabelle delle decisioni

Una tabella decisionale rappresenta le condizioni e le rispettive azioni da intraprendere per affrontarle, in un formato tabulare strutturato.

È un potente strumento per eseguire il debug e prevenire gli errori. Aiuta a raggruppare informazioni simili in un'unica tabella e quindi combinando le tabelle offre un processo decisionale facile e conveniente.

Creazione della tabella delle decisioni

Per creare la tabella decisionale, lo sviluppatore deve seguire i quattro passaggi di base:

  • Identificare tutte le possibili condizioni da affrontare
  • Determina le azioni per tutte le condizioni identificate
  • Crea il numero massimo di regole possibili
  • Definisci l'azione per ogni regola

Le tabelle delle decisioni dovrebbero essere verificate dagli utenti finali e possono essere semplificate ultimamente eliminando regole e azioni duplicate.

Esempio

Facciamo un semplice esempio del problema quotidiano con la nostra connettività Internet. Iniziamo identificando tutti i problemi che possono sorgere durante l'avvio di Internet e le rispettive possibili soluzioni.

Elenchiamo tutti i possibili problemi nelle condizioni della colonna e le azioni prospettiche nella colonna Azioni.

Condizioni / azioni Regole
Condizioni Spettacoli collegati N N N N Y Y Y Y
Ping sta funzionando N N Y Y N N Y Y
Apre il sito web Y N Y N Y N Y N
Azioni Verificare il cavo di rete X
Controlla il router Internet X X X X
Riavvia il browser web X
Contatta il fornitore di servizi X X X X X X
Nessuna azione
Tabella: Tabella decisionale - Risoluzione dei problemi Internet interna

Modello Entità-Relazione

Il modello Entità-Relazione è un tipo di modello di database basato sulla nozione di entità del mondo reale e relazione tra di loro. Possiamo mappare lo scenario del mondo reale sul modello di database ER. ER Model crea un insieme di entità con i loro attributi, un insieme di vincoli e relazioni tra di loro.

Il modello ER è utilizzato al meglio per la progettazione concettuale del database. Il modello ER può essere rappresentato come segue:

  • Entity - Un'entità in ER Model è un essere del mondo reale, che ha alcune proprietà chiamate attributes. Ogni attributo è definito dal suo insieme di valori corrispondente, chiamatodomain.

    Ad esempio, considera un database scolastico. Qui uno studente è un'entità. Lo studente ha vari attributi come nome, id, età e classe ecc.

  • Relationship - Viene chiamata l'associazione logica tra entità relationship. Le relazioni vengono mappate con le entità in vari modi. Le cardinalità di mappatura definiscono il numero di associazioni tra due entità.

    Mappatura delle cardinalità:

    • uno a uno
    • uno a molti
    • molti a uno
    • molti a molti

Dizionario dei dati

Il dizionario dei dati è la raccolta centralizzata di informazioni sui dati. Memorizza il significato e l'origine dei dati, la loro relazione con altri dati, il formato dei dati per l'utilizzo, ecc. Il dizionario dei dati ha definizioni rigorose di tutti i nomi per facilitare i progettisti di software e utenti.

Il dizionario dei dati viene spesso definito come repository di metadati (dati sui dati). Viene creato insieme al modello DFD (Data Flow Diagram) del programma software e si prevede che venga aggiornato ogni volta che DFD viene modificato o aggiornato.

Requisiti del dizionario dei dati

I dati vengono referenziati tramite dizionario dati durante la progettazione e l'implementazione del software. Il dizionario dei dati elimina ogni possibilità di ambiguità. Aiuta a mantenere sincronizzato il lavoro di programmatori e progettisti utilizzando lo stesso riferimento a oggetti ovunque nel programma.

Il dizionario dei dati fornisce una modalità di documentazione per l'intero sistema di database in un unico posto. La convalida del DFD viene eseguita utilizzando il dizionario dei dati.

Contenuti

Il dizionario dati dovrebbe contenere informazioni su quanto segue

  • Flusso di dati
  • Struttura dati
  • Elementi di dati
  • Archivi dati
  • Elaborazione dati

Il flusso di dati è descritto mediante DFD come studiato in precedenza e rappresentato in forma algebrica come descritto.

= Composto da
{} Ripetizione
() Opzionale
+ E
[/] O

Esempio

Indirizzo = numero civico + (via / area) + città + stato

ID corso = numero del corso + nome del corso + livello del corso + voti del corso

Elementi di dati

Gli elementi dei dati sono costituiti da nome e descrizioni di dati e elementi di controllo, archivi di dati interni o esterni ecc. Con i seguenti dettagli:

  • Nome principale
  • Nome secondario (alias)
  • Caso d'uso (come e dove utilizzarlo)
  • Descrizione del contenuto (notazione ecc.)
  • Informazioni supplementari (valori preimpostati, vincoli ecc.)

Archivio dati

Memorizza le informazioni da dove i dati entrano nel sistema ed escono dal sistema. Il Data Store può includere:

  • Files
    • Interno al software.
    • Esterno al software ma sulla stessa macchina.
    • Esterno al software e al sistema, situato su una macchina diversa.
  • Tables
    • Convenzione di denominazione
    • Proprietà di indicizzazione

Elaborazione dati

Esistono due tipi di trattamento dei dati:

  • Logical: Come lo vede l'utente
  • Physical: Come lo vede il software

La progettazione del software è un processo per concettualizzare i requisiti software nell'implementazione del software. La progettazione del software prende le esigenze dell'utente come sfide e cerca di trovare una soluzione ottimale. Durante la concettualizzazione del software, viene elaborato un piano per trovare il miglior design possibile per l'implementazione della soluzione prevista.

Esistono più varianti di progettazione del software. Analizziamoli brevemente:

Design strutturato

Il design strutturato è una concettualizzazione del problema in diversi elementi di soluzione ben organizzati. Fondamentalmente si occupa della progettazione della soluzione. Il vantaggio del design strutturato è che offre una migliore comprensione di come il problema viene risolto. Il design strutturato rende anche più semplice per il progettista concentrarsi sul problema in modo più accurato.

La progettazione strutturata si basa principalmente sulla strategia "divide et impera" in cui un problema viene suddiviso in diversi piccoli problemi e ogni piccolo problema viene risolto individualmente finché non viene risolto l'intero problema.

I piccoli pezzi del problema vengono risolti mediante moduli di soluzione. Il design strutturato sottolinea che questi moduli devono essere ben organizzati per ottenere una soluzione precisa.

Questi moduli sono disposti in gerarchia. Comunicano tra loro. Un buon design strutturato segue sempre alcune regole per la comunicazione tra più moduli, vale a dire:

Cohesion - raggruppamento di tutti gli elementi funzionalmente correlati.

Coupling - comunicazione tra diversi moduli.

Un buon design strutturato ha un'elevata coesione e bassi accordi di accoppiamento.

Design orientato alla funzione

Nella progettazione orientata alla funzione, il sistema è composto da molti sottosistemi più piccoli noti come funzioni. Queste funzioni sono in grado di eseguire attività significative nel sistema. Il sistema è considerato come vista dall'alto di tutte le funzioni.

Il design orientato alla funzione eredita alcune proprietà del design strutturato in cui viene utilizzata la metodologia divide et impera.

Questo meccanismo di progettazione divide l'intero sistema in funzioni più piccole, che fornisce mezzi di astrazione nascondendo le informazioni e il loro funzionamento. Questi moduli funzionali possono condividere le informazioni tra loro mediante il passaggio di informazioni e utilizzando le informazioni disponibili a livello globale.

Un'altra caratteristica delle funzioni è che quando un programma chiama una funzione, la funzione cambia lo stato del programma, che a volte non è accettabile da altri moduli. Il design orientato alla funzione funziona bene dove lo stato del sistema non ha importanza e il programma / le funzioni lavorano sull'input piuttosto che su uno stato.

Processo di progettazione

  • L'intero sistema è visto come il modo in cui i dati fluiscono nel sistema per mezzo del diagramma di flusso dei dati.
  • DFD descrive come le funzioni cambiano i dati e lo stato dell'intero sistema.
  • L'intero sistema è logicamente suddiviso in unità più piccole note come funzioni sulla base del loro funzionamento nel sistema.
  • Ciascuna funzione viene quindi descritta in generale.

Design orientato agli oggetti

La progettazione orientata agli oggetti lavora intorno alle entità e alle loro caratteristiche invece che alle funzioni coinvolte nel sistema software. Questa strategia di progettazione si concentra sulle entità e sulle sue caratteristiche. L'intero concetto di soluzione software ruota attorno alle entità coinvolte.

Vediamo i concetti importanti di Object Oriented Design:

  • Objects - Tutte le entità coinvolte nella progettazione della soluzione sono note come oggetti. Ad esempio, persona, banca, azienda e clienti vengono trattati come oggetti. Ogni entità ha alcuni attributi ad essa associati e ha alcuni metodi da eseguire sugli attributi.
  • Classes - Una classe è una descrizione generalizzata di un oggetto. Un oggetto è un'istanza di una classe. La classe definisce tutti gli attributi che un oggetto può avere e i metodi che definiscono la funzionalità dell'oggetto.

    Nella progettazione della soluzione, gli attributi vengono memorizzati come variabili e le funzionalità vengono definite mediante metodi o procedure.

  • Encapsulation - In OOD, gli attributi (variabili di dati) e metodi (operazione sui dati) sono raggruppati insieme è chiamato incapsulamento. L'incapsulamento non solo raggruppa le informazioni importanti di un oggetto, ma limita anche l'accesso ai dati e ai metodi dal mondo esterno. Questo si chiama nascondere le informazioni.
  • Inheritance - L'OOD consente a classi simili di accumularsi in modo gerarchico in cui le classi inferiori o le sottoclassi possono importare, implementare e riutilizzare variabili e metodi consentiti dalle loro super classi immediate. Questa proprietà di OOD è nota come eredità. Ciò semplifica la definizione di classi specifiche e la creazione di classi generalizzate da quelle specifiche.
  • Polymorphism - I linguaggi OOD forniscono un meccanismo in cui ai metodi che eseguono attività simili ma variano negli argomenti, può essere assegnato lo stesso nome. Questo è chiamato polimorfismo, che consente a un'unica interfaccia di eseguire attività per diversi tipi. A seconda di come viene richiamata la funzione, viene eseguita la rispettiva porzione di codice.

Processo di progettazione

Il processo di progettazione del software può essere percepito come una serie di passaggi ben definiti. Sebbene varia in base all'approccio di progettazione (orientato alla funzione o orientato agli oggetti, tuttavia può comportare i seguenti passaggi:

  • Un progetto di soluzione viene creato dal requisito o dal sistema utilizzato in precedenza e / o dal diagramma di sequenza del sistema.
  • Gli oggetti vengono identificati e raggruppati in classi per conto della somiglianza nelle caratteristiche degli attributi.
  • La gerarchia di classe e la relazione tra di loro è definita.
  • Il framework dell'applicazione è definito.

Approcci alla progettazione del software

Ecco due approcci generici per la progettazione del software:

Design dall'alto verso il basso

Sappiamo che un sistema è composto da più di un sottosistema e contiene un numero di componenti. Inoltre, questi sottosistemi e componenti possono avere il loro insieme di sottosistemi e componenti e creano una struttura gerarchica nel sistema.

La progettazione top-down prende l'intero sistema software come un'entità e poi lo scompone per ottenere più di un sottosistema o componente in base ad alcune caratteristiche. Ogni sottosistema o componente viene quindi trattato come un sistema e ulteriormente scomposto. Questo processo continua finché non viene raggiunto il livello di sistema più basso nella gerarchia top-down.

La progettazione top-down inizia con un modello di sistema generalizzato e continua a definirne la parte più specifica. Quando tutti i componenti sono composti, l'intero sistema viene all'esistenza.

La progettazione top-down è più adatta quando la soluzione software deve essere progettata da zero e i dettagli specifici sono sconosciuti.

Design dal basso

Il modello di progettazione dal basso verso l'alto inizia con i componenti più specifici e di base. Procede con la composizione di componenti di livello superiore utilizzando componenti di livello base o inferiore. Continua a creare componenti di livello superiore fino a quando il sistema desiderato non si evolve come un singolo componente. Con ogni livello più alto, la quantità di astrazione aumenta.

La strategia bottom-up è più adatta quando è necessario creare un sistema da un sistema esistente, in cui le primitive di base possono essere utilizzate nel sistema più recente.

Entrambi gli approcci dall'alto verso il basso e dal basso verso l'alto non sono pratici individualmente. Viene invece utilizzata una buona combinazione di entrambi.

L'interfaccia utente è la visualizzazione dell'applicazione front-end con cui l'utente interagisce per utilizzare il software. L'utente può manipolare e controllare il software così come l'hardware tramite l'interfaccia utente. Oggi, l'interfaccia utente si trova in quasi tutti i luoghi in cui esiste la tecnologia digitale, direttamente da computer, telefoni cellulari, automobili, lettori musicali, aeroplani, navi ecc.

L'interfaccia utente fa parte del software ed è progettata in modo tale da fornire all'utente informazioni dettagliate sul software. L'interfaccia utente fornisce una piattaforma fondamentale per l'interazione uomo-computer.

L'interfaccia utente può essere grafica, basata su testo, audio-video, a seconda della combinazione hardware e software sottostante. L'interfaccia utente può essere hardware o software o una combinazione di entrambi.

Il software diventa più popolare se la sua interfaccia utente è:

  • Attractive
  • Semplice da usare
  • Reattivo in breve tempo
  • Chiaro da capire
  • Coerente su tutti gli schermi di interfacciamento

L'interfaccia utente è ampiamente suddivisa in due categorie:

  • Interfaccia della riga di comando
  • Interfaccia grafica utente

Interfaccia della riga di comando (CLI)

CLI è stato un ottimo strumento di interazione con i computer fino a quando non sono nati i monitor di visualizzazione video. La CLI è la prima scelta di molti utenti tecnici e programmatori. La CLI è l'interfaccia minima che un software può fornire ai suoi utenti.

CLI fornisce un prompt dei comandi, il luogo in cui l'utente digita il comando e invia il feed al sistema. L'utente deve ricordare la sintassi del comando e il suo utilizzo. La CLI precedente non era programmata per gestire in modo efficace gli errori dell'utente.

Un comando è un riferimento basato su testo a una serie di istruzioni che dovrebbero essere eseguite dal sistema. Esistono metodi come macro, script che facilitano il funzionamento dell'utente.

La CLI utilizza una quantità minore di risorse del computer rispetto alla GUI.

Elementi CLI

Un'interfaccia della riga di comando basata su testo può avere i seguenti elementi:

  • Command Prompt- È un notificatore basato su testo che mostra principalmente il contesto in cui sta lavorando l'utente. Viene generato dal sistema software.

  • Cursor- È una piccola linea orizzontale o una barra verticale dell'altezza della linea, per rappresentare la posizione del carattere durante la digitazione. Il cursore si trova principalmente nello stato lampeggiante. Si sposta mentre l'utente scrive o cancella qualcosa.

  • Command- Un comando è un'istruzione eseguibile. Può avere uno o più parametri. L'output durante l'esecuzione del comando viene mostrato in linea sullo schermo. Quando viene prodotto l'output, il prompt dei comandi viene visualizzato nella riga successiva.

Interfaccia grafica utente

L'interfaccia utente grafica fornisce all'utente i mezzi grafici per interagire con il sistema. La GUI può essere una combinazione di hardware e software. Utilizzando la GUI, l'utente interpreta il software.

In genere, la GUI consuma più risorse rispetto a quella della CLI. Con l'avanzare della tecnologia, i programmatori e i progettisti creano progetti GUI complessi che funzionano con maggiore efficienza, precisione e velocità.

Elementi della GUI

La GUI fornisce una serie di componenti per interagire con software o hardware.

Ogni componente grafico fornisce un modo per lavorare con il sistema. Un sistema GUI ha i seguenti elementi come:

  • Window- Un'area in cui vengono visualizzati i contenuti dell'applicazione. Il contenuto di una finestra può essere visualizzato sotto forma di icone o elenchi, se la finestra rappresenta la struttura del file. È più facile per un utente navigare nel file system in una finestra di esplorazione. Windows può essere ridotto a icona, ridimensionato o ingrandito in base alle dimensioni dello schermo. Possono essere spostati ovunque sullo schermo. Una finestra può contenere un'altra finestra della stessa applicazione, chiamata finestra figlia.

  • Tabs - Se un'applicazione consente di eseguire più istanze di se stessa, vengono visualizzate sullo schermo come finestre separate. Tabbed Document Interfaceè arrivato per aprire più documenti nella stessa finestra. Questa interfaccia aiuta anche a visualizzare il pannello delle preferenze nell'applicazione. Tutti i browser Web moderni utilizzano questa funzione.

  • Menu- Menu è un array di comandi standard, raggruppati e posizionati in un punto visibile (solitamente in alto) all'interno della finestra dell'applicazione. Il menu può essere programmato per essere visualizzato o nascosto ai clic del mouse.

  • Icon- Un'icona è una piccola immagine che rappresenta un'applicazione associata. Quando si fa clic o si fa doppio clic su queste icone, si apre la finestra dell'applicazione. L'icona mostra l'applicazione e i programmi installati su un sistema sotto forma di piccole immagini.

  • Cursor- I dispositivi interagenti come mouse, touch pad, penna digitale sono rappresentati nella GUI come cursori. Il cursore sullo schermo segue le istruzioni dall'hardware quasi in tempo reale. I cursori sono anche denominati puntatori nei sistemi GUI. Sono utilizzati per selezionare menu, finestre e altre funzionalità dell'applicazione.

Componenti GUI specifici dell'applicazione

Una GUI di un'applicazione contiene uno o più degli elementi GUI elencati:

  • Application Window - La maggior parte delle finestre dell'applicazione utilizza i costrutti forniti dai sistemi operativi, ma molti utilizzano le finestre create dai propri clienti per contenere il contenuto dell'applicazione.

  • Dialogue Box - È una finestra figlia che contiene un messaggio per l'utente e la richiesta di intraprendere un'azione. Ad esempio: l'applicazione genera una finestra di dialogo per ottenere la conferma da parte dell'utente per l'eliminazione di un file.

  • Text-Box - Fornisce un'area in cui l'utente può digitare e immettere dati basati su testo.

  • Buttons - Imitano i pulsanti della vita reale e vengono utilizzati per inviare input al software.

  • Radio-button- Visualizza le opzioni disponibili per la selezione. È possibile selezionarne solo uno tra tutti quelli offerti.

  • Check-box- Funzioni simili alla casella di riepilogo. Quando un'opzione è selezionata, la casella è contrassegnata come selezionata. È possibile selezionare più opzioni rappresentate da caselle di controllo.

  • List-box - Fornisce un elenco di elementi disponibili per la selezione. È possibile selezionare più di un elemento.

Altri componenti GUI impressionanti sono:

  • Sliders
  • Combo-box
  • Data-grid
  • Menu `A tendina

Attività di progettazione dell'interfaccia utente

Esistono numerose attività eseguite per la progettazione dell'interfaccia utente. Il processo di progettazione e implementazione della GUI è simile all'SDLC. Qualsiasi modello può essere utilizzato per l'implementazione della GUI tra Waterfall, Iterative o Spiral Model.

Un modello utilizzato per la progettazione e lo sviluppo della GUI dovrebbe soddisfare questi passaggi specifici della GUI.

  • GUI Requirement Gathering- I progettisti potrebbero voler avere un elenco di tutti i requisiti funzionali e non funzionali della GUI. Questo può essere preso dall'utente e dalla sua soluzione software esistente.

  • User Analysis- Il progettista studia chi utilizzerà la GUI del software. Il pubblico di destinazione è importante poiché i dettagli del design cambiano in base al livello di conoscenza e competenza dell'utente. Se l'utente è esperto di tecnologia, è possibile incorporare una GUI avanzata e complessa. Per un utente inesperto, sono incluse ulteriori informazioni sulle procedure per il software.

  • Task Analysis- I progettisti devono analizzare quale compito deve essere svolto dalla soluzione software. Qui nella GUI, non importa come sarà fatto. Le attività possono essere rappresentate in modo gerarchico prendendo un compito principale e dividendolo ulteriormente in sotto-compiti più piccoli. Le attività forniscono obiettivi per la presentazione della GUI. Il flusso di informazioni tra le attività secondarie determina il flusso dei contenuti della GUI nel software.

  • GUI Design & implementation- I progettisti dopo aver ricevuto informazioni sui requisiti, le attività e l'ambiente utente, progettano la GUI e le implementazioni nel codice e incorporano la GUI con software funzionante o fittizio in background. Viene quindi auto-testato dagli sviluppatori.

  • Testing- Il test della GUI può essere eseguito in vari modi. L'organizzazione può avere l'ispezione interna, il coinvolgimento diretto degli utenti e il rilascio della versione beta sono alcuni di questi. I test possono includere usabilità, compatibilità, accettazione dell'utente, ecc.

Strumenti di implementazione della GUI

Sono disponibili diversi strumenti che consentono ai progettisti di creare l'intera GUI con un clic del mouse. Alcuni strumenti possono essere incorporati nell'ambiente software (IDE).

Gli strumenti di implementazione della GUI forniscono una potente gamma di controlli GUI. Per la personalizzazione del software, i progettisti possono modificare il codice di conseguenza.

Esistono diversi segmenti di strumenti GUI in base al loro diverso utilizzo e piattaforma.

Esempio

GUI mobile, GUI del computer, GUI touch-screen ecc. Di seguito è riportato un elenco di alcuni strumenti utili per creare una GUI:

  • FLUID
  • AppInventor (Android)
  • LucidChart
  • Wavemaker
  • Visual Studio

Regole d'oro dell'interfaccia utente

Le seguenti regole sono indicate come le regole d'oro per la progettazione di GUI, descritte da Shneiderman e Plaisant nel loro libro (Designing the User Interface).

  • Strive for consistency- Dovrebbero essere richieste sequenze di azioni coerenti in situazioni simili. Una terminologia identica dovrebbe essere utilizzata nei prompt, nei menu e nelle schermate della guida. Dovrebbero essere impiegati comandi coerenti.

  • Enable frequent users to use short-cuts- Il desiderio dell'utente di ridurre il numero di interazioni aumenta con la frequenza di utilizzo. Abbreviazioni, tasti funzione, comandi nascosti e funzionalità macro sono molto utili per un utente esperto.

  • Offer informative feedback- Per ogni azione dell'operatore, dovrebbe esserci un feedback di sistema. Per azioni frequenti e minori, la risposta deve essere modesta, mentre per azioni poco frequenti e importanti la risposta deve essere più sostanziale.

  • Design dialog to yield closure- Le sequenze di azioni dovrebbero essere organizzate in gruppi con un inizio, una parte centrale e una fine. Il feedback informativo al completamento di un gruppo di azioni dà agli operatori la soddisfazione della realizzazione, un senso di sollievo, il segnale per eliminare i piani di emergenza e le opzioni dalle loro menti, e questo indica che la strada da percorrere è chiara per prepararsi al prossimo gruppo di azioni.

  • Offer simple error handling- Per quanto possibile, progettare il sistema in modo che l'utente non commetta errori gravi. Se viene commesso un errore, il sistema dovrebbe essere in grado di rilevarlo e offrire meccanismi semplici e comprensibili per la gestione dell'errore.

  • Permit easy reversal of actions- Questa funzione allevia l'ansia, poiché l'utente sa che gli errori possono essere annullati. La facile inversione delle azioni incoraggia l'esplorazione di opzioni non familiari. Le unità di reversibilità possono essere una singola azione, un'immissione di dati o un gruppo completo di azioni.

  • Support internal locus of control- Gli operatori esperti desiderano fortemente la sensazione di essere responsabili del sistema e che il sistema risponda alle loro azioni. Progettare il sistema per rendere gli utenti gli iniziatori delle azioni piuttosto che i responder.

  • Reduce short-term memory load - La limitazione dell'elaborazione delle informazioni umane nella memoria a breve termine richiede che i display siano mantenuti semplici, le visualizzazioni di più pagine siano consolidate, la frequenza di movimento delle finestre sia ridotta e sia assegnato un tempo di addestramento sufficiente per codici, mnemonici e sequenze di azioni.

Il termine complessità sta per stato di eventi o cose, che hanno più collegamenti interconnessi e strutture altamente complicate. Nella programmazione del software, man mano che la progettazione del software viene realizzata, il numero di elementi e le loro interconnessioni diventano gradualmente enormi, il che diventa troppo difficile da capire immediatamente.

La complessità della progettazione del software è difficile da valutare senza utilizzare metriche e misure di complessità. Vediamo tre importanti misure di complessità del software.

Misure di complessità di Halstead

Nel 1977, il signor Maurice Howard Halstead ha introdotto le metriche per misurare la complessità del software. Le metriche di Halstead dipendono dall'effettiva implementazione del programma e dalle sue misure, che vengono calcolate direttamente dagli operatori e dagli operandi dal codice sorgente, in modo statico. Consente di valutare il tempo di test, il vocabolario, le dimensioni, la difficoltà, gli errori e gli sforzi per il codice sorgente C / C ++ / Java.

Secondo Halstead, "Un programma per computer è un'implementazione di un algoritmo considerato come una raccolta di token che possono essere classificati come operatori o operandi". Le metriche di Halstead pensano a un programma come una sequenza di operatori e i loro operandi associati.

Definisce vari indicatori per verificare la complessità del modulo.

Parametro Senso
n1 Numero di operatori univoci
n2 Numero di operandi univoci
N1 Numero di occorrenze totali di operatori
N2 Numero di occorrenze totali di operandi

Quando selezioniamo il file di origine per visualizzarne i dettagli di complessità in Metric Viewer, il seguente risultato viene visualizzato in Metric Report:

Metrico Senso Rappresentazione matematica
n Vocabolario n1 + n2
N Taglia N1 + N2
V Volume Lunghezza * Log2 Vocabolario
D Difficoltà (n1 / 2) * (N1 / n2)
E Sforzi Difficoltà * Volume
B Errori Volume / 3000
T Tempo di prova Tempo = Sforzi / S, dove S = 18 secondi.

Misure di complessità ciclomatica

Ogni programma comprende istruzioni da eseguire per eseguire alcune attività e altre dichiarazioni decisionali che decidono quali istruzioni devono essere eseguite. Questi costrutti decisionali cambiano il flusso del programma.

Se confrontiamo due programmi della stessa dimensione, quello con più dichiarazioni decisionali sarà più complesso poiché il controllo del programma salta frequentemente.

McCabe, nel 1976, propose Cyclomatic Complexity Measure per quantificare la complessità di un dato software. È un modello basato su grafici che si basa su costrutti decisionali del programma come if-else, do-while, repeat-until, switch-case e goto.

Processo per creare un grafico di controllo del flusso:

  • Interrompi il programma in blocchi più piccoli, delimitati da costrutti decisionali.
  • Crea nodi che rappresentano ciascuno di questi nodi.
  • Connetti i nodi come segue:
    • Se il controllo può diramarsi dal blocco i al blocco j

      Disegna un arco

    • Da nodo di uscita a nodo di ingresso

      Disegna un arco.

Per calcolare la complessità ciclomatica di un modulo di programma, usiamo la formula -

V(G) = e – n + 2

Where
e is total number of edges
n is total number of nodes

La complessità ciclomatica del modulo sopra è

e = 10
n = 8
Cyclomatic Complexity = 10 - 8 + 2
                      = 4

Secondo P. Jorgensen, la complessità ciclomatica di un modulo non dovrebbe superare 10.

Punto funzione

È ampiamente utilizzato per misurare le dimensioni del software. Function Point si concentra sulle funzionalità fornite dal sistema. Le caratteristiche e le funzionalità del sistema vengono utilizzate per misurare la complessità del software.

Il punto funzione conta su cinque parametri, denominati Ingresso esterno, Uscita esterna, File interni logici, File di interfaccia esterna e Richiesta esterna. Per considerare la complessità del software, ogni parametro viene ulteriormente classificato come semplice, medio o complesso.

Vediamo i parametri del punto funzione:

Ingresso esterno

Ogni input univoco al sistema, dall'esterno, è considerato come input esterno. Viene misurata l'unicità dell'input, poiché non esistono due input dovrebbero avere gli stessi formati. Questi input possono essere dati o parametri di controllo.

  • Simple - se il numero di input è basso e influisce su meno file interni

  • Complex - se il numero di input è elevato e influisce su più file interni

  • Average - tra semplice e complesso.

Uscita esterna

Tutti i tipi di output forniti dal sistema vengono conteggiati in questa categoria. L'output è considerato unico se il formato e / o l'elaborazione di output sono unici.

  • Simple - se il conteggio delle uscite è basso

  • Complex - se il conteggio delle uscite è alto

  • Average - tra semplice e complesso.

File interni logici

Ogni sistema software conserva i file interni per mantenere le proprie informazioni funzionali e per funzionare correttamente. Questi file contengono dati logici del sistema. Questi dati logici possono contenere sia dati funzionali che dati di controllo.

  • Simple - se il numero di tipi di record è basso

  • Complex - se il numero di tipi di record è elevato

  • Average - tra semplice e complesso.

File di interfaccia esterna

Il sistema software potrebbe dover condividere i propri file con un software esterno o potrebbe essere necessario passare il file per l'elaborazione o come parametro per alcune funzioni. Tutti questi file vengono conteggiati come file di interfaccia esterna.

  • Simple - se il numero di tipi di record nel file condiviso è basso

  • Complex - se il numero di tipi di record nel file condiviso è elevato

  • Average - tra semplice e complesso.

Indagine esterna

Un'indagine è una combinazione di input e output, in cui l'utente invia alcuni dati su cui interrogare come input e il sistema risponde all'utente con l'output della richiesta elaborata. La complessità di una query è più che un input esterno e un output esterno. Si dice che la query è univoca se il suo input e output sono unici in termini di formato e dati.

  • Simple - se la query richiede una bassa elaborazione e produce una piccola quantità di dati di output

  • Complex - se la query richiede un processo elevato e produce una grande quantità di dati di output

  • Average - tra semplice e complesso.

A ciascuno di questi parametri nel sistema viene assegnato un peso in base alla loro classe e complessità. La tabella seguente menziona il peso assegnato a ciascun parametro:

Parametro Semplice Media Complesso
Ingressi 3 4 6
Uscite 4 5 7
Inchiesta 3 4 6
File 7 10 15
Interfacce 5 7 10

La tabella sopra fornisce i punti funzione grezzi. Questi punti funzione vengono regolati in base alla complessità dell'ambiente. Il sistema è descritto utilizzando quattordici diverse caratteristiche:

  • Comunicazione dei dati
  • Elaborazione distribuita
  • Obiettivi di performance
  • Caricamento configurazione operazione
  • Tasso di transazione
  • Inserimento dati online,
  • Efficienza dell'utente finale
  • Aggiornamento in linea
  • Logica di elaborazione complessa
  • Re-usability
  • Facilità di installazione
  • Facilità operativa
  • Più siti
  • Desiderio di facilitare i cambiamenti

Questi fattori caratteristici vengono quindi valutati da 0 a 5, come indicato di seguito:

  • Nessuna influenza
  • Incidental
  • Moderate
  • Average
  • Significant
  • Essential

Tutte le valutazioni vengono quindi sommate come N. Il valore di N varia da 0 a 70 (14 tipi di caratteristiche x 5 tipi di valutazioni). Viene utilizzato per calcolare i fattori di regolazione della complessità (CAF), utilizzando le seguenti formule:

CAF = 0.65 + 0.01N

Poi,

Delivered Function Points (FP)= CAF x Raw FP

Questo FP può quindi essere utilizzato in varie metriche, come ad esempio:

    Cost = $ / FP

    Quality = Errori / FP

    Productivity = FP / persona-mese

In questo capitolo studieremo i metodi di programmazione, la documentazione e le sfide nell'implementazione del software.

Programmazione strutturata

Nel processo di codifica, le righe di codice continuano a moltiplicarsi, quindi la dimensione del software aumenta. A poco a poco, diventa quasi impossibile ricordare il flusso del programma. Se si dimentica come sono costruiti il ​​software ei suoi programmi, file e procedure sottostanti, diventa molto difficile condividere, eseguire il debug e modificare il programma. La soluzione a questo problema è la programmazione strutturata. Incoraggia lo sviluppatore a utilizzare subroutine e loop invece di utilizzare semplici salti nel codice, portando così chiarezza nel codice e migliorandone l'efficienza La programmazione strutturata aiuta anche il programmatore a ridurre i tempi di codifica e organizzare il codice correttamente.

La programmazione strutturata stabilisce la modalità di codifica del programma. La programmazione strutturata utilizza tre concetti principali:

  • Top-down analysis- Un software è sempre fatto per eseguire un lavoro razionale. Questo lavoro razionale è noto come problema nel linguaggio del software. Quindi è molto importante capire come risolvere il problema. Sotto l'analisi top-down, il problema è suddiviso in piccoli pezzi in cui ognuno ha un significato. Ogni problema viene risolto individualmente e i passaggi sono chiaramente indicati su come risolvere il problema.

  • Modular Programming- Durante la programmazione, il codice viene suddiviso in piccoli gruppi di istruzioni. Questi gruppi sono noti come moduli, sottoprogrammi o sottoprogrammi. Programmazione modulare basata sulla comprensione dell'analisi top-down. Scoraggia i salti utilizzando le istruzioni "goto" nel programma, il che spesso rende il flusso del programma non tracciabile. I salti sono proibiti e il formato modulare è incoraggiato nella programmazione strutturata.

  • Structured Coding - In riferimento all'analisi top-down, la codifica strutturata suddivide i moduli in ulteriori unità di codice più piccole nell'ordine di esecuzione. La programmazione strutturata utilizza la struttura di controllo, che controlla il flusso del programma, mentre la codifica strutturata utilizza la struttura di controllo per organizzare le sue istruzioni in modelli definibili.

Programmazione funzionale

La programmazione funzionale è lo stile del linguaggio di programmazione, che utilizza i concetti delle funzioni matematiche. Una funzione in matematica dovrebbe sempre produrre lo stesso risultato quando riceve lo stesso argomento. Nei linguaggi procedurali, il flusso del programma attraversa le procedure, cioè il controllo del programma viene trasferito alla procedura chiamata. Durante il trasferimento del flusso di controllo da una procedura all'altra, il programma cambia il proprio stato.

Nella programmazione procedurale, è possibile che una procedura produca risultati diversi quando viene chiamata con lo stesso argomento, poiché il programma stesso può trovarsi in uno stato diverso durante la chiamata. Questa è una proprietà oltre che uno svantaggio della programmazione procedurale, in cui la sequenza o la tempistica dell'esecuzione della procedura diventa importante.

La programmazione funzionale fornisce mezzi di calcolo come funzioni matematiche, che producono risultati indipendentemente dallo stato del programma. Ciò consente di prevedere il comportamento del programma.

La programmazione funzionale utilizza i seguenti concetti:

  • First class and High-order functions - Queste funzioni hanno la capacità di accettare un'altra funzione come argomento o restituiscono altre funzioni come risultati.

  • Pure functions - Queste funzioni non includono aggiornamenti distruttivi, cioè non influenzano alcun I / O o memoria e se non sono in uso, possono essere facilmente rimosse senza ostacolare il resto del programma.

  • Recursion- La ricorsione è una tecnica di programmazione in cui una funzione richiama se stessa e ripete il codice del programma al suo interno a meno che una condizione predefinita non corrisponda. La ricorsione è il modo di creare cicli nella programmazione funzionale.

  • Strict evaluation- È un metodo per valutare l'espressione passata a una funzione come argomento. La programmazione funzionale ha due tipi di metodi di valutazione, rigoroso (desideroso) o non rigoroso (pigro). Una valutazione rigorosa valuta sempre l'espressione prima di richiamare la funzione. La valutazione non rigorosa non valuta l'espressione a meno che non sia necessaria.

  • λ-calculus- La maggior parte dei linguaggi di programmazione funzionale utilizza λ-calcolo come sistema di tipi. Le espressioni λ vengono eseguite valutandole man mano che si verificano.

Common Lisp, Scala, Haskell, Erlang e F # sono alcuni esempi di linguaggi di programmazione funzionali.

Stile di programmazione

Lo stile di programmazione è un insieme di regole di codifica seguite da tutti i programmatori per scrivere il codice. Quando più programmatori lavorano sullo stesso progetto software, spesso devono lavorare con il codice del programma scritto da qualche altro sviluppatore. Ciò diventa noioso o talvolta impossibile, se tutti gli sviluppatori non seguono uno stile di programmazione standard per codificare il programma.

Uno stile di programmazione appropriato include l'uso di nomi di funzioni e variabili rilevanti per l'attività prevista, l'utilizzo di rientri ben posizionati, commenti di codice per comodità del lettore e presentazione generale del codice. Ciò rende il codice del programma leggibile e comprensibile da tutti, il che a sua volta semplifica il debug e la risoluzione degli errori. Inoltre, uno stile di codifica corretto aiuta a facilitare la documentazione e l'aggiornamento.

Linee guida per la codifica

La pratica dello stile di codifica varia a seconda delle organizzazioni, dei sistemi operativi e del linguaggio di codifica stesso.

I seguenti elementi di codifica possono essere definiti nelle linee guida di codifica di un'organizzazione:

  • Naming conventions - Questa sezione definisce come denominare funzioni, variabili, costanti e variabili globali.

  • Indenting - Questo è lo spazio lasciato all'inizio della riga, di solito 2-8 spazi bianchi o una singola scheda.

  • Whitespace - Viene generalmente omesso alla fine della riga.

  • Operators- Definisce le regole di scrittura di operatori matematici, di assegnazione e logici. Ad esempio, l'operatore di assegnazione "=" deve contenere uno spazio prima e dopo di esso, come in "x = 2".

  • Control Structures - Le regole per scrivere if-then-else, case-switch, while-until e per le istruzioni del flusso di controllo esclusivamente e in modo annidato.

  • Line length and wrapping- Definisce quanti caratteri devono essere presenti in una riga, principalmente una riga è lunga 80 caratteri. Il wrapping definisce il modo in cui una riga deve essere mandata a capo, se è troppo lunga.

  • Functions - Definisce come le funzioni devono essere dichiarate e invocate, con e senza parametri.

  • Variables - Indica come vengono dichiarate e definite le variabili di diversi tipi di dati.

  • Comments- Questo è uno dei componenti di codifica importanti, poiché i commenti inclusi nel codice descrivono ciò che il codice fa effettivamente e tutte le altre descrizioni associate. Questa sezione aiuta anche a creare documentazioni di aiuto per altri sviluppatori.

Documentazione software

La documentazione del software è una parte importante del processo del software. Un documento ben scritto fornisce un ottimo strumento e mezzo di archivio di informazioni necessarie per conoscere il processo del software. La documentazione del software fornisce anche informazioni su come utilizzare il prodotto.

Una documentazione ben conservata dovrebbe comprendere i seguenti documenti:

  • Requirement documentation - Questa documentazione funziona come strumento chiave per il progettista, lo sviluppatore e il team di test del software per svolgere le rispettive attività. Questo documento contiene tutte le descrizioni funzionali, non funzionali e comportamentali del software previsto.

    La fonte di questo documento possono essere dati precedentemente memorizzati sul software, software già in esecuzione presso il cliente, interviste, questionari e ricerche del cliente. Generalmente viene archiviato sotto forma di foglio di calcolo o documento di elaborazione testi presso il team di gestione del software di fascia alta.

    Questa documentazione funge da base per il software da sviluppare e viene utilizzata principalmente nelle fasi di verifica e convalida. La maggior parte dei casi di test vengono creati direttamente dalla documentazione dei requisiti.

  • Software Design documentation - Queste documentazioni contengono tutte le informazioni necessarie, che sono necessarie per costruire il software. Contiene:(a) Architettura software di alto livello, (b) Dettagli di progettazione del software, (c) Diagrammi di flusso dei dati, (d) Progettazione di database

    Questi documenti funzionano come repository per gli sviluppatori per implementare il software. Sebbene questi documenti non forniscano dettagli su come codificare il programma, forniscono tutte le informazioni necessarie per la codifica e l'implementazione.

  • Technical documentation- Queste documentazioni sono mantenute dagli sviluppatori e dai programmatori effettivi. Questi documenti, nel loro insieme, rappresentano informazioni sul codice. Durante la scrittura del codice, i programmatori menzionano anche l'obiettivo del codice, chi lo ha scritto, dove sarà richiesto, cosa fa e come fa, quali altre risorse utilizza il codice, ecc.

    La documentazione tecnica aumenta la comprensione tra i vari programmatori che lavorano sullo stesso codice. Migliora la capacità di riutilizzo del codice. Rende il debug facile e tracciabile.

    Sono disponibili vari strumenti automatizzati e alcuni vengono forniti con il linguaggio di programmazione stesso. Ad esempio java arriva lo strumento JavaDoc per generare la documentazione tecnica del codice.

  • User documentation- Questa documentazione è diversa da quanto sopra spiegato. Tutta la documentazione precedente viene mantenuta per fornire informazioni sul software e sul suo processo di sviluppo. Ma la documentazione per l'utente spiega come dovrebbe funzionare il prodotto software e come dovrebbe essere utilizzato per ottenere i risultati desiderati.

    Queste documentazioni possono includere procedure di installazione del software, guide pratiche, guide per l'utente, metodi di disinstallazione e riferimenti speciali per ottenere maggiori informazioni come l'aggiornamento della licenza, ecc.

Sfide nell'implementazione del software

Ci sono alcune sfide affrontate dal team di sviluppo durante l'implementazione del software. Alcuni di loro sono menzionati di seguito:

  • Code-reuse- Le interfacce di programmazione dei linguaggi odierni sono molto sofisticate e sono dotate di enormi funzioni di libreria. Tuttavia, per ridurre il costo del prodotto finale, la direzione dell'organizzazione preferisce riutilizzare il codice, che è stato creato in precedenza per alcuni altri software. Ci sono enormi problemi che i programmatori devono affrontare per i controlli di compatibilità e per decidere quanto codice riutilizzare.

  • Version Management- Ogni volta che viene rilasciato un nuovo software al cliente, gli sviluppatori devono mantenere la documentazione relativa alla versione e alla configurazione. Questa documentazione deve essere estremamente accurata e disponibile in tempo.

  • Target-Host- Il programma software, che è in fase di sviluppo nell'organizzazione, deve essere progettato per le macchine host presso i clienti. Ma a volte è impossibile progettare un software che funzioni sulle macchine target.

Il test del software è la valutazione del software rispetto ai requisiti raccolti dagli utenti e alle specifiche del sistema. Il test viene condotto a livello di fase nel ciclo di vita dello sviluppo del software oa livello di modulo nel codice del programma. Il test del software comprende la convalida e la verifica.

Validazione del software

La convalida è un processo per esaminare se il software soddisfa o meno i requisiti dell'utente. Viene eseguito alla fine dell'SDLC. Se il software soddisfa i requisiti per i quali è stato creato, viene convalidato.

  • La convalida garantisce che il prodotto in fase di sviluppo sia conforme ai requisiti dell'utente.
  • La convalida risponde alla domanda: "Stiamo sviluppando il prodotto che tenta tutto ciò di cui l'utente ha bisogno da questo software?".
  • La convalida enfatizza i requisiti dell'utente.

Verifica del software

La verifica è il processo per confermare se il software soddisfa i requisiti aziendali ed è sviluppato aderendo alle specifiche e alle metodologie appropriate.

  • La verifica garantisce che il prodotto in fase di sviluppo sia conforme alle specifiche di progettazione.
  • La verifica risponde alla domanda: "Stiamo sviluppando questo prodotto seguendo fermamente tutte le specifiche di progettazione?"
  • Le verifiche si concentrano sulla progettazione e sulle specifiche del sistema.

Obiettivo del test sono:

  • Errors- Questi sono errori di codifica effettivi commessi dagli sviluppatori. Inoltre, c'è una differenza nell'output del software e l'output desiderato, è considerato un errore.

  • Fault- Quando esiste un errore, si verifica un guasto. Un errore, noto anche come bug, è il risultato di un errore che può causare il malfunzionamento del sistema.

  • Failure - si dice che il fallimento è l'incapacità del sistema di eseguire l'attività desiderata. Il guasto si verifica quando esiste un guasto nel sistema.

Test manuale vs automatizzato

Il test può essere eseguito manualmente o utilizzando uno strumento di test automatizzato:

  • Manual- Questo test viene eseguito senza l'ausilio di strumenti di test automatizzati. Il tester software prepara casi di test per diverse sezioni e livelli del codice, esegue i test e riporta il risultato al manager.

    Il test manuale richiede tempo e risorse. Il tester deve confermare se vengono utilizzati o meno casi di test corretti. La maggior parte dei test prevede test manuali.

  • AutomatedQuesto test è una procedura di test eseguita con l'ausilio di strumenti di test automatizzati. I limiti del test manuale possono essere superati utilizzando strumenti di test automatizzati.

Un test deve verificare se una pagina Web può essere aperta in Internet Explorer. Questo può essere fatto facilmente con il test manuale. Ma per verificare se il server web può sopportare il carico di 1 milione di utenti, è del tutto impossibile testarlo manualmente.

Esistono strumenti software e hardware che aiutano i tester a condurre test di carico, stress test, test di regressione.

Approcci di prova

I test possono essere condotti sulla base di due approcci:

  • Test di funzionalità
  • Test di implementazione

Quando la funzionalità viene testata senza considerare l'implementazione effettiva, è noto come test della scatola nera. L'altro lato è noto come test white-box in cui non viene testata solo la funzionalità, ma viene anche analizzato il modo in cui viene implementata.

I test approfonditi sono il metodo migliore per un test perfetto. Viene testato ogni singolo valore possibile nell'intervallo dei valori di ingresso e uscita. Non è possibile testare ogni singolo valore nello scenario del mondo reale se l'intervallo di valori è ampio.

Test in scatola nera

Viene eseguito per testare la funzionalità del programma. È anche chiamato test "comportamentale". Il tester in questo caso ha una serie di valori di input e rispettivi risultati desiderati. Quando si fornisce input, se l'output corrisponde ai risultati desiderati, il programma viene testato "ok" e problematico in caso contrario.

In questo metodo di test, il design e la struttura del codice non sono noti al tester e gli ingegneri di test e gli utenti finali conducono questo test sul software.

Tecniche di test black-box:

  • Equivalence class- L'input è suddiviso in classi simili. Se un elemento di una classe supera il test, si presume che tutta la classe sia passata.

  • Boundary values- L'input è diviso in valori finali superiore e inferiore. Se questi valori superano il test, si presume che anche tutti i valori intermedi possano passare.

  • Cause-effect graphing- In entrambi i metodi precedenti, viene testato un solo valore di input alla volta. Causa (input) - Effetto (output) è una tecnica di test in cui le combinazioni di valori di input vengono testate in modo sistematico.

  • Pair-wise Testing- Il comportamento del software dipende da più parametri. Nel test a coppie, i parametri multipli vengono testati a coppie per i loro diversi valori.

  • State-based testing- Il sistema cambia stato quando viene fornito l'input. Questi sistemi vengono testati in base ai loro stati e input.

Test white-box

Viene condotto per testare il programma e la sua implementazione, al fine di migliorare l'efficienza o la struttura del codice. È anche noto come test "strutturale".

In questo metodo di prova, il tester conosce il design e la struttura del codice. I programmatori del codice conducono questo test sul codice.

Di seguito sono riportate alcune tecniche di test White-box:

  • Control-flow testing- Lo scopo del test del flusso di controllo per impostare casi di test che coprano tutte le istruzioni e le condizioni del ramo. Le condizioni del ramo vengono verificate sia per essere vere che per false, in modo che tutte le affermazioni possano essere coperte.

  • Data-flow testing- Questa tecnica di test punta a coprire tutte le variabili di dati incluse nel programma. Verifica dove sono state dichiarate e definite le variabili e dove sono state utilizzate o modificate.

Livelli di prova

Il test stesso può essere definito a vari livelli di SDLC. Il processo di test viene eseguito parallelamente allo sviluppo del software. Prima di passare alla fase successiva, una fase viene testata, convalidata e verificata.

Il test separatamente viene eseguito solo per assicurarsi che non ci siano bug o problemi nascosti nel software. Il software è testato a vari livelli:

Test unitario

Durante la codifica, il programmatore esegue alcuni test su quell'unità di programma per sapere se è esente da errori. Il test viene eseguito con un approccio di test white-box. I test unitari aiutano gli sviluppatori a decidere che le singole unità del programma funzionano secondo i requisiti e sono prive di errori.

Test d'integrazione

Anche se le unità del software funzionano bene individualmente, è necessario scoprire se le unità, se integrate insieme, funzionerebbero anche senza errori. Ad esempio, passaggio di argomenti e aggiornamento dei dati, ecc.

Test di sistema

Il software viene compilato come prodotto e quindi testato nel suo insieme. Questa operazione può essere eseguita utilizzando uno o più dei seguenti test:

  • Functionality testing - Verifica tutte le funzionalità del software rispetto ai requisiti.

  • Performance testing- Questo test dimostra quanto sia efficiente il software. Verifica l'efficacia e il tempo medio impiegato dal software per eseguire l'attività desiderata. Il test delle prestazioni viene eseguito mediante test di carico e stress test in cui il software viene sottoposto a un elevato carico di utenti e dati in varie condizioni ambientali.

  • Security & Portability - Questi test vengono eseguiti quando il software deve funzionare su varie piattaforme e vi si accede in base al numero di persone.

Test di accettazione

Quando il software è pronto per essere consegnato al cliente, deve passare attraverso l'ultima fase di test in cui viene testato per l'interazione e la risposta dell'utente. Questo è importante perché anche se il software soddisfa tutti i requisiti dell'utente e se all'utente non piace il modo in cui appare o funziona, potrebbe essere rifiutato.

  • Alpha testing- Gli stessi team di sviluppatori eseguono i test alpha utilizzando il sistema come se fosse utilizzato nell'ambiente di lavoro. Cercano di scoprire come reagirebbe l'utente a un'azione nel software e come il sistema dovrebbe rispondere agli input.

  • Beta testing- Dopo che il software è stato testato internamente, viene consegnato agli utenti per utilizzarlo nel loro ambiente di produzione solo a scopo di test. Questo non è ancora il prodotto consegnato. Gli sviluppatori si aspettano che gli utenti in questa fase porteranno piccoli problemi, che sono stati ignorati per partecipare.

Test di regressione

Ogni volta che un prodotto software viene aggiornato con un nuovo codice, caratteristica o funzionalità, viene testato accuratamente per rilevare se c'è un impatto negativo del codice aggiunto. Questo è noto come test di regressione.

Documentazione di test

I documenti di prova vengono preparati in diverse fasi:

Prima del test

Il test inizia con la generazione dei casi di test. I seguenti documenti sono necessari per riferimento:

  • SRS document - Documento Requisiti Funzionali

  • Test Policy document - Descrive la durata del test prima di rilasciare il prodotto.

  • Test Strategy document - Questo menziona aspetti dettagliati del team di test, matrice di responsabilità e diritti / responsabilità del responsabile del test e dell'ingegnere del test.

  • Traceability Matrix document- Questo è un documento SDLC, correlato al processo di raccolta dei requisiti. Man mano che arrivano nuovi requisiti, vengono aggiunti a questa matrice. Queste matrici aiutano i tester a conoscere la fonte del requisito. Possono essere tracciati avanti e indietro.

Durante il test

I seguenti documenti possono essere richiesti durante l'avvio e l'esecuzione del test:

  • Test Case document- Questo documento contiene l'elenco dei test che devono essere condotti. Include un piano di test unitario, un piano di test di integrazione, un piano di test di sistema e un piano di test di accettazione.

  • Test description - Questo documento è una descrizione dettagliata di tutti i casi di test e delle procedure per eseguirli.

  • Test case report - Questo documento contiene il rapporto del caso di test come risultato del test.

  • Test logs - Questo documento contiene i registri dei test per ogni rapporto sui casi di test.

Dopo il test

I seguenti documenti possono essere generati dopo il test:

  • Test summary- Questo riepilogo del test è un'analisi collettiva di tutti i rapporti e registri dei test. Riassume e conclude se il software è pronto per essere lanciato. Il software viene rilasciato sotto il sistema di controllo della versione se è pronto per il lancio.

Test vs controllo di qualità, garanzia di qualità e audit

Dobbiamo capire che il test del software è diverso dalla garanzia della qualità del software, dal controllo della qualità del software e dall'audit del software.

  • Software quality assurance- Si tratta di mezzi di monitoraggio del processo di sviluppo del software, attraverso i quali si garantisce che tutte le misure siano prese secondo gli standard di organizzazione. Questo monitoraggio viene eseguito per assicurarsi che siano stati seguiti i metodi di sviluppo del software appropriati.

  • Software quality control- Questo è un sistema per mantenere la qualità del prodotto software. Può includere aspetti funzionali e non funzionali del prodotto software, che migliorano la buona volontà dell'organizzazione. Questo sistema garantisce che il cliente riceva un prodotto di qualità per le sue esigenze e il prodotto certificato come "idoneo all'uso".

  • Software audit- Questa è una revisione della procedura utilizzata dall'organizzazione per sviluppare il software. Un team di auditor, indipendente dal team di sviluppo, esamina il processo, la procedura, i requisiti e altri aspetti dell'SDLC del software. Lo scopo dell'audit del software è verificare che il software e il suo processo di sviluppo siano conformi a standard, regole e regolamenti.

La manutenzione del software è ormai ampiamente accettata come parte di SDLC. Significa tutte le modifiche e gli aggiornamenti effettuati dopo la consegna del prodotto software. Ci sono diversi motivi per cui sono necessarie modifiche, alcune delle quali sono brevemente menzionate di seguito:

  • Market Conditions - Le politiche, che cambiano nel tempo, come la tassazione e vincoli di recente introduzione come, come mantenere la contabilità, possono far scattare la necessità di modifiche.

  • Client Requirements - Nel tempo, il cliente potrebbe richiedere nuove caratteristiche o funzioni nel software.

  • Host Modifications - Se l'hardware e / o la piattaforma (come il sistema operativo) dell'host di destinazione cambia, sono necessarie modifiche al software per mantenere l'adattabilità.

  • Organization Changes - Se si verifica un cambiamento a livello di business alla fine del cliente, come la riduzione della forza dell'organizzazione, l'acquisizione di un'altra azienda, l'organizzazione che si avventura in nuove attività, può sorgere la necessità di modificare il software originale.

Tipi di manutenzione

Durante la vita del software, il tipo di manutenzione può variare in base alla sua natura. Potrebbe essere solo un'attività di manutenzione ordinaria come un bug scoperto da qualche utente o potrebbe essere un evento di grandi dimensioni in sé basato sulle dimensioni o sulla natura della manutenzione. Di seguito sono riportati alcuni tipi di manutenzione in base alle loro caratteristiche:

  • Corrective Maintenance - Ciò include modifiche e aggiornamenti effettuati per correggere o risolvere problemi, che vengono rilevati dall'utente o conclusi da rapporti di errore dell'utente.

  • Adaptive Maintenance - Ciò include modifiche e aggiornamenti applicati per mantenere il prodotto software aggiornato e sintonizzato sul mondo in continua evoluzione della tecnologia e dell'ambiente aziendale.

  • Perfective Maintenance- Ciò include modifiche e aggiornamenti effettuati al fine di mantenere il software utilizzabile per un lungo periodo di tempo. Include nuove funzionalità, nuovi requisiti utente per perfezionare il software e migliorarne l'affidabilità e le prestazioni.

  • Preventive Maintenance- Ciò include modifiche e aggiornamenti per evitare problemi futuri del software. Ha lo scopo di assistere i problemi, che non sono significativi in ​​questo momento, ma possono causare seri problemi in futuro.

Costo della manutenzione

I rapporti suggeriscono che il costo della manutenzione è elevato. Uno studio sulla stima della manutenzione del software ha rilevato che il costo della manutenzione raggiunge il 67% del costo dell'intero ciclo di processo del software.

In media, il costo della manutenzione del software è superiore al 50% di tutte le fasi dell'SDLC. Ci sono vari fattori che determinano un aumento dei costi di manutenzione, come ad esempio:

Fattori del mondo reale che influenzano i costi di manutenzione

  • L'età standard di qualsiasi software è considerata fino a 10-15 anni.
  • I software più vecchi, che dovevano funzionare su macchine lente con meno memoria e capacità di archiviazione, non possono resistere alla sfida contro i nuovi software avanzati su hardware moderno.
  • Con l'avanzare della tecnologia, diventa costoso mantenere il vecchio software.
  • La maggior parte dei tecnici della manutenzione è alle prime armi e utilizza metodi di prova ed errore per correggere il problema.
  • Spesso, le modifiche apportate possono facilmente danneggiare la struttura originale del software, rendendo difficile qualsiasi modifica successiva.
  • Le modifiche spesso vengono lasciate non documentate, il che potrebbe causare ulteriori conflitti in futuro.

Fattori di fine software che influenzano i costi di manutenzione

  • Struttura del programma software
  • Linguaggio di programmazione
  • Dipendenza dall'ambiente esterno
  • Affidabilità e disponibilità del personale

Attività di manutenzione

IEEE fornisce una struttura per le attività del processo di manutenzione sequenziale. Può essere utilizzato in modo iterativo e può essere esteso in modo da includere elementi e processi personalizzati.

Queste attività vanno di pari passo con ciascuna delle seguenti fasi:

  • Identification & Tracing- Implica attività relative all'individuazione del requisito di modifica o manutenzione. Viene generato dall'utente o il sistema stesso può segnalare tramite log o messaggi di errore, qui viene classificato anche il tipo di manutenzione.

  • Analysis- La modifica viene analizzata per il suo impatto sul sistema, comprese le implicazioni di sicurezza e protezione. Se il probabile impatto è grave, si cerca una soluzione alternativa. Una serie di modifiche richieste viene quindi concretizzata nelle specifiche dei requisiti. Si analizza il costo di modifica / manutenzione e si conclude la stima.

  • Design- I nuovi moduli, che devono essere sostituiti o modificati, sono progettati in base alle specifiche dei requisiti fissate nella fase precedente. I casi di test vengono creati per la convalida e la verifica.

  • Implementation - I nuovi moduli sono codificati con l'aiuto di un design strutturato creato nella fase di progettazione. Ogni programmatore dovrebbe eseguire unit test in parallelo.

  • System Testing- Il test di integrazione viene eseguito tra i moduli di nuova creazione. Viene inoltre eseguito il test di integrazione tra i nuovi moduli e il sistema. Infine il sistema viene testato nel suo complesso, seguendo procedure di test regressivo.

  • Acceptance Testing- Dopo aver testato internamente il sistema, viene testato per l'accettazione con l'aiuto degli utenti. Se in questo stato l'utente lamenta alcuni problemi, vengono risolti o annotati per risolverli nella successiva iterazione.

  • Delivery- Dopo il test di accettazione, il sistema viene distribuito in tutta l'organizzazione tramite un piccolo pacchetto di aggiornamento o una nuova installazione del sistema. Il test finale avviene al cliente dopo la consegna del software.

    Se necessario, viene fornita una struttura di formazione, oltre alla copia cartacea del manuale dell'utente.

  • Maintenance management- La gestione della configurazione è una parte essenziale della manutenzione del sistema. È supportato con strumenti di controllo della versione per controllare le versioni, la semi-versione o la gestione delle patch.

Reingegnerizzazione del software

Quando abbiamo bisogno di aggiornare il software per mantenerlo al mercato attuale, senza influire sulla sua funzionalità, si parla di reingegnerizzazione del software. È un processo completo in cui il design del software viene modificato e i programmi vengono riscritti.

Il software legacy non è in grado di mantenere la sintonizzazione con la tecnologia più recente disponibile sul mercato. Man mano che l'hardware diventa obsoleto, l'aggiornamento del software diventa un mal di testa. Anche se il software invecchia con il tempo, la sua funzionalità non lo fa.

Ad esempio, inizialmente Unix è stato sviluppato in linguaggio assembly. Quando il linguaggio C è nato, Unix è stato riprogettato in C, perché lavorare in linguaggio assembly era difficile.

Oltre a questo, a volte i programmatori notano che poche parti del software richiedono più manutenzione di altre e hanno anche bisogno di una riprogettazione.

Processo di reingegnerizzazione

  • Decidecosa riprogettare. È un intero software o una parte di esso?
  • Perform Reverse Engineering, al fine di ottenere le specifiche del software esistente.
  • Restructure Programse richiesto. Ad esempio, cambiare i programmi orientati alle funzioni in programmi orientati agli oggetti.
  • Re-structure data come richiesto.
  • Apply Forward engineering concetti per ottenere software riprogettato.

Ci sono pochi termini importanti usati nella riprogettazione del software

Reverse Engineering

È un processo per ottenere le specifiche del sistema analizzando e comprendendo a fondo il sistema esistente. Questo processo può essere visto come un modello SDLC inverso, ovvero cerchiamo di ottenere un livello di astrazione più elevato analizzando livelli di astrazione più bassi.

Un sistema esistente è precedentemente implementato design, di cui non sappiamo nulla. I progettisti quindi eseguono il reverse engineering guardando il codice e provano a ottenere il progetto. Con il design in mano, cercano di concludere le specifiche. Quindi, andando al contrario dal codice alla specifica del sistema.

Ristrutturazione del programma

È un processo per ri-strutturare e ricostruire il software esistente. Si tratta di riorganizzare il codice sorgente, nello stesso linguaggio di programmazione o da un linguaggio di programmazione a uno diverso. La ristrutturazione può comportare la ristrutturazione del codice sorgente e la ristrutturazione dei dati o entrambe.

La ristrutturazione non influisce sulla funzionalità del software ma migliora l'affidabilità e la manutenibilità. I componenti del programma, che causano errori molto frequentemente, possono essere modificati o aggiornati con la ristrutturazione.

L'affidabilità del software su una piattaforma hardware obsoleta può essere rimossa tramite la ristrutturazione.

Forward Engineering

Il forward engineering è un processo per ottenere il software desiderato dalle specifiche in mano che sono state eliminate mediante reverse engineering. Si presume che in passato fosse già stata eseguita un'ingegneria del software.

Il forward engineering è lo stesso del processo di ingegneria del software con una sola differenza: viene eseguito sempre dopo il reverse engineering.

Riutilizzabilità dei componenti

Un componente è una parte del codice del programma software, che esegue un'attività indipendente nel sistema. Può essere un piccolo modulo o un sottosistema stesso.

Esempio

Le procedure di accesso utilizzate sul web possono essere considerate come componenti, il sistema di stampa nel software può essere visto come un componente del software.

I componenti hanno un'elevata coesione di funzionalità e un tasso di accoppiamento inferiore, ovvero funzionano in modo indipendente e possono svolgere compiti senza dipendere da altri moduli.

In OOP, gli oggetti progettati sono molto specifici per la loro preoccupazione e hanno meno possibilità di essere utilizzati in altri software.

Nella programmazione modulare, i moduli sono codificati per eseguire attività specifiche che possono essere utilizzate attraverso numerosi altri programmi software.

Esiste un verticale completamente nuovo, basato sul riutilizzo di componenti software, noto come Component Based Software Engineering (CBSE).

Il riutilizzo può essere effettuato a vari livelli

  • Application level - Quando un'intera applicazione viene utilizzata come sottosistema di nuovo software.

  • Component level - Dove viene utilizzato il sottosistema di un'applicazione.

  • Modules level - Dove i moduli funzionali vengono riutilizzati.

    I componenti software forniscono interfacce che possono essere utilizzate per stabilire la comunicazione tra diversi componenti.

Processo di riutilizzo

È possibile adottare due tipi di metodo: mantenendo gli stessi requisiti e regolando i componenti oppure mantenendo gli stessi componenti e modificando i requisiti.

  • Requirement Specification - Vengono specificati i requisiti funzionali e non funzionali ai quali un prodotto software deve soddisfare, con l'aiuto del sistema esistente, l'input dell'utente o entrambi.

  • Design- Questa è anche una fase del processo SDLC standard, in cui i requisiti sono definiti in termini di linguaggio software. Viene creata l'architettura di base del sistema nel suo insieme e dei suoi sottosistemi.

  • Specify Components - Studiando la progettazione del software, i progettisti separano l'intero sistema in componenti o sottosistemi più piccoli. Un progetto software completo si trasforma in una raccolta di un enorme set di componenti che lavorano insieme.

  • Search Suitable Components - Il repository dei componenti software viene indirizzato dai progettisti per cercare il componente corrispondente, sulla base della funzionalità e dei requisiti software previsti.

  • Incorporate Components - Tutti i componenti abbinati vengono imballati insieme per modellarli come software completo.

CASE sta per Computer Aided Software Engineering. Significa, sviluppo e manutenzione di progetti software con l'aiuto di vari strumenti software automatizzati.

Strumenti CASE

Gli strumenti CASE sono un insieme di programmi applicativi software, utilizzati per automatizzare le attività SDLC. Gli strumenti CASE vengono utilizzati da project manager software, analisti e ingegneri per sviluppare il sistema software.

Sono disponibili numerosi strumenti CASE per semplificare le varie fasi del ciclo di vita dello sviluppo del software come strumenti di analisi, strumenti di progettazione, strumenti di gestione del progetto, strumenti di gestione del database, strumenti di documentazione sono solo per citarne alcuni.

L'utilizzo degli strumenti CASE accelera lo sviluppo del progetto per produrre il risultato desiderato e aiuta a scoprire i difetti prima di procedere con la fase successiva dello sviluppo del software.

Componenti degli strumenti CASE

Gli strumenti CASE possono essere ampiamente suddivisi nelle seguenti parti in base al loro utilizzo in una particolare fase SDLC:

  • Central Repository- Gli strumenti CASE richiedono un archivio centrale, che può fungere da fonte di informazioni comuni, integrate e coerenti. Il repository centrale è un luogo di archiviazione centrale in cui vengono archiviate le specifiche del prodotto, i documenti dei requisiti, i rapporti e i diagrammi correlati, altre informazioni utili sulla gestione. Il repository centrale funge anche da dizionario dei dati.

  • Upper Case Tools - Gli strumenti MAIUSC vengono utilizzati nelle fasi di pianificazione, analisi e progettazione dell'SDLC.

  • Lower Case Tools - Gli strumenti CASE inferiori vengono utilizzati nell'implementazione, nel test e nella manutenzione.

  • Integrated Case Tools - Gli strumenti CASE integrati sono utili in tutte le fasi dell'SDLC, dalla raccolta dei requisiti al test e alla documentazione.

Gli strumenti CASE possono essere raggruppati se hanno funzionalità simili, attività di processo e capacità di integrarsi con altri strumenti.

Scopo degli strumenti del caso

L'ambito degli strumenti CASE copre tutto l'SDLC.

Tipi di strumenti del caso

Ora esaminiamo brevemente i vari strumenti CASE

Strumenti del diagramma

Questi strumenti vengono utilizzati per rappresentare i componenti del sistema, i dati e il flusso di controllo tra i vari componenti software e la struttura del sistema in forma grafica. Ad esempio, lo strumento Flow Chart Maker per la creazione di diagrammi di flusso all'avanguardia.

Strumenti di modellazione del processo

La modellazione del processo è un metodo per creare il modello di processo del software, che viene utilizzato per sviluppare il software. Gli strumenti di modellazione del processo aiutano i manager a scegliere un modello di processo o modificarlo secondo i requisiti del prodotto software. Ad esempio, EPF Composer

Strumenti di gestione del progetto

Questi strumenti vengono utilizzati per la pianificazione del progetto, la stima dei costi e degli sforzi, la pianificazione del progetto e la pianificazione delle risorse. I manager devono rispettare rigorosamente l'esecuzione del progetto in ogni fase menzionata nella gestione del progetto software. Gli strumenti di gestione del progetto aiutano a memorizzare e condividere le informazioni sul progetto in tempo reale in tutta l'organizzazione. Ad esempio, Creative Pro Office, Trac Project, Basecamp.

Strumenti di documentazione

La documentazione in un progetto software inizia prima del processo software, attraversa tutte le fasi dell'SDLC e dopo il completamento del progetto.

Gli strumenti di documentazione generano documenti per utenti tecnici e utenti finali. Gli utenti tecnici sono per lo più professionisti interni del team di sviluppo che fanno riferimento al manuale del sistema, al manuale di riferimento, al manuale di formazione, ai manuali di installazione, ecc. I documenti per l'utente finale descrivono il funzionamento e le procedure del sistema, come il manuale dell'utente. Ad esempio, Doxygen, DrExplain, Adobe RoboHelp per la documentazione.

Strumenti di analisi

Questi strumenti aiutano a raccogliere i requisiti, a controllare automaticamente eventuali incongruenze, imprecisioni nei diagrammi, ridondanze dei dati o omissioni errate. Ad esempio, Accept 360, Accompa, CaseComplete per l'analisi dei requisiti, Visible Analyst per l'analisi totale.

Strumenti di progettazione

Questi strumenti aiutano i progettisti di software a progettare la struttura a blocchi del software, che può essere ulteriormente suddivisa in moduli più piccoli utilizzando tecniche di perfezionamento. Questi strumenti forniscono i dettagli di ogni modulo e le interconnessioni tra i moduli. Ad esempio, Animated Software Design

Strumenti di gestione della configurazione

Un'istanza di software viene rilasciata in una versione. Gli strumenti di gestione della configurazione si occupano di:

  • Gestione delle versioni e delle revisioni
  • Gestione della configurazione di base
  • Gestione del controllo delle modifiche

Gli strumenti CASE aiutano in questo con il monitoraggio automatico, la gestione delle versioni e la gestione dei rilasci. Ad esempio, Fossil, Git, Accu REV.

Cambia strumenti di controllo

Questi strumenti sono considerati parte degli strumenti di gestione della configurazione. Si occupano delle modifiche apportate al software dopo che la sua linea di base è stata corretta o quando il software viene rilasciato per la prima volta. Gli strumenti CASE automatizzano il rilevamento delle modifiche, la gestione dei file, la gestione del codice e altro ancora. Aiuta anche a far rispettare la politica di cambiamento dell'organizzazione.

Strumenti di programmazione

Questi strumenti sono costituiti da ambienti di programmazione come IDE (Integrated Development Environment), libreria di moduli incorporati e strumenti di simulazione. Questi strumenti forniscono un aiuto completo nella creazione di prodotti software e includono funzionalità per la simulazione e il test. Ad esempio, Cscope per cercare codice in C, Eclipse.

Strumenti di prototipazione

Il prototipo software è la versione simulata del prodotto software previsto. Il prototipo fornisce l'aspetto iniziale del prodotto e simula pochi aspetti del prodotto reale.

Gli strumenti CASE di prototipazione sono essenzialmente dotati di librerie grafiche. Possono creare interfacce utente e design indipendenti dall'hardware. Questi strumenti ci aiutano a costruire prototipi rapidi sulla base delle informazioni esistenti. Inoltre, forniscono la simulazione del prototipo del software. Ad esempio, il compositore prototipo di Serena, Mockup Builder.

Strumenti di sviluppo web

Questi strumenti aiutano nella progettazione di pagine web con tutti gli elementi alleati come moduli, testo, script, grafica e così via. Gli strumenti Web forniscono anche un'anteprima in tempo reale di ciò che viene sviluppato e di come sarà dopo il completamento. Ad esempio, Fontello, Adobe Edge Inspect, Foundation 3, Brackets.

Strumenti di garanzia della qualità

La garanzia della qualità in un'organizzazione di software consiste nel monitorare il processo di ingegneria e i metodi adottati per sviluppare il prodotto software al fine di garantire la conformità della qualità secondo gli standard dell'organizzazione. Gli strumenti di controllo qualità sono costituiti da strumenti di controllo della configurazione e delle modifiche e strumenti di test del software. Ad esempio, SoapTest, AppsWatch, JMeter.

Strumenti di manutenzione

La manutenzione del software include modifiche al prodotto software dopo la consegna. Tecniche di registrazione automatica e segnalazione degli errori, generazione automatica di ticket di errore e analisi della causa principale sono pochi strumenti CASE, che aiutano l'organizzazione del software nella fase di manutenzione di SDLC. Ad esempio, Bugzilla per il tracciamento dei difetti, HP Quality Center.