![軟件工程(研究生)全冊配套課件3_第1頁](http://file4.renrendoc.com/view12/M08/15/07/wKhkGWbYOiyAab_2AAJAdtArhiw471.jpg)
![軟件工程(研究生)全冊配套課件3_第2頁](http://file4.renrendoc.com/view12/M08/15/07/wKhkGWbYOiyAab_2AAJAdtArhiw4712.jpg)
![軟件工程(研究生)全冊配套課件3_第3頁](http://file4.renrendoc.com/view12/M08/15/07/wKhkGWbYOiyAab_2AAJAdtArhiw4713.jpg)
![軟件工程(研究生)全冊配套課件3_第4頁](http://file4.renrendoc.com/view12/M08/15/07/wKhkGWbYOiyAab_2AAJAdtArhiw4714.jpg)
![軟件工程(研究生)全冊配套課件3_第5頁](http://file4.renrendoc.com/view12/M08/15/07/wKhkGWbYOiyAab_2AAJAdtArhiw4715.jpg)
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
軟件工程(研究生)全冊配套課件3NationalEngineeringCenterforCADSoftwareEngineeringHuazhongUniversityofScienceandTechnologyNationalEngineeringCenterforCADDr.LiuQinghualiuqh@
Chapter1:IntroductionObjectives:tointroducesoftwareengineeringandtoprovideaframeworkforunderstandingsoftwareengineering.Understandwhatsoftwareengineeringisandwhyitisimportant;Understandthatthedevelopmentofdifferenttypesofsoftwaresystemsmayrequiredifferentsoftwareengineeringtechniques;Understandsomeethicalandprofessionalissuesthatareimportantforsoftwareengineers;Beintroducedtothreesystems,ofdifferenttypes,thatwillbeusedasexamplesthroughoutthebook.HistoryofsoftwareengineeringThenotionof‘softwareengineering’wasfirstproposedin1968ataconferenceheldtodiscusswhatwasthencalledthe‘softwarecrisis’.Itbecameclearthatindividualapproachestoprogramdevelopmentdidnotscaleuptolargeandcomplexsoftwaresystems.Thesewereunreliable,costmorethanexpected,andweredeliveredlate.Throughoutthe1970sand1980s,avarietyofnewsoftwareengineeringtechniquesandmethodsweredeveloped,suchasstructuredprogramming,informationhidingandobject-orienteddevelopment.Toolsandstandardnotationsweredevelopedandarenowextensivelyused.ContentsProfessionalSoftwareDevelopmentSoftwareengineeringethicsCaseStudySoftwareandsoftwareengineeringWecan’trunthemodernworldwithoutsoftware.Softwaresystemsareabstractandintangible.Theyarenotconstrainedbythepropertiesofmaterials,governedbyphysicallaws,orbymanufacturingprocesses.Thissimplifiessoftwareengineering.Softwaresystemscanquicklybecomeextremelycomplex,difficulttounderstand,andexpensivetochange.Therearemanydifferenttypesofsoftwaresystems,fromsimpleembeddedsystemstocomplex,worldwideinformationsystems.Itispointlesstolookforuniversalnotations,methods,ortechniquesforsoftwareengineeringbecausedifferenttypesofsoftwarerequiredifferentsoftwareengineeringtechniques.SoftwareFailuresSoftwarefailuresaremainlyconsequenceoftwofactors:Increasingdemands
andChangingdemandsSystemshavetobebuiltanddeliveredmorequicklyLarger,evenmorecomplexsystemsarerequiredSystemshavetohavenewcapabilitiesthatwerepreviouslythoughttobeimpossible.ExistingsoftwareengineeringmethodscannotcopeandnewSEtechniqueshavetobedevelopedtomeetthesenewdemands.LowexpectationsItisrelativelyeasytowritecomputerprogramswithoutusingsoftwareengineeringmethodsandtechniques.Manycompanieshavedriftedintosoftwaredevelopmentastheirproductsandserviceshaveevolved.Theydonotusesoftwareengineeringmethodsintheireverydaywork.1.1ProfessionalsoftwaredevelopmentLotsofpeoplewriteprograms.Professionalsoftware,intendedforusebysomeoneapartfromitsdeveloper,isusuallydevelopedbyteamsratherthanindividualsSoftwareengineeringisintendedtosupportprofessionalsoftwaredevelopmentratherthanindividualprogramming.Somefrequentlyaskedquestions(FAQs)aboutsoftwareengineeringarelistinthefollowingpage.FAQsaboutsoftwareengineeringQuestionAnswerWhatissoftware?Computerprogramsandassociateddocumentation.Softwareproductsmaybedevelopedforaparticularcustomerormaybedevelopedforageneralmarket.Whataretheattributesofgoodsoftware?Goodsoftwareshoulddelivertherequiredfunctionalityandperformancetotheuserandshouldbemaintainable,dependableandusable.Whatissoftwareengineering?Softwareengineeringisanengineeringdisciplinethatisconcernedwithallaspectsofsoftwareproduction.Whatarethefundamentalsoftwareengineeringactivities?Softwarespecification,softwaredevelopment,softwarevalidationandsoftwareevolution.Whatisthedifferencebetweensoftwareengineeringandcomputerscience?Computersciencefocusesontheoryandfundamentals;softwareengineeringisconcernedwiththepracticalitiesofdevelopinganddeliveringusefulsoftware.Whatisthedifferencebetweensoftwareengineeringandsystemengineering?Systemengineeringisconcernedwithallaspectsofcomputer-basedsystemsdevelopmentincludinghardware,softwareandprocessengineering.Softwareengineeringispartofthismoregeneralprocess.Whatarethekeychallengesfacingsoftwareengineering?Copingwithincreasingdiversity,demandsforreduceddeliverytimesanddevelopingtrustworthysoftware.Whatarethecostsofsoftwareengineering?Roughly60%ofsoftwarecostsaredevelopmentcosts,40%aretestingcosts.Forcustomsoftware,evolutioncostsoftenexceeddevelopmentcosts.Whatarethebestsoftwareengineeringtechniquesandmethods?Whileallsoftwareprojectshavetobeprofessionallymanagedanddeveloped,differenttechniquesareappropriatefordifferenttypesofsystem.Forexample,gamesshouldalwaysbedevelopedusingaseriesofprototypeswhereassafetycriticalcontrolsystemsrequireacompleteandanalyzablespecificationtobedeveloped.Youcan’t,therefore,saythatonemethodisbetterthananother.Whatdifferenceshasthewebmadetosoftwareengineering?Thewebhasledtotheavailabilityofsoftwareservicesandthepossibilityofdevelopinghighlydistributedservice-basedsystems.Web-basedsystemsdevelopmenthasledtoimportantadvancesinprogramminglanguagesandsoftwarereuse.TwokindsofsoftwareproductsGenericproductsThesearestand-alonesystemsthatareproducedbyadevelopmentorganizationandsoldontheopenmarkettoanycustomerwhoisabletobuythem.Theorganizationthatdevelopsthesoftwarecontrolsthesoftwarespecification.Customized(orbespoke)productsThesearesystemsthatarecommissionedbyaparticularcustomer.Thespecificationisusuallydevelopedandcontrolledbytheorganizationthatisbuyingthesoftware.AnimportantdifferencebetweenthetwoDistinctionisbecomingblurredMoreandmoresystemsarenowbeingbuiltwithagenericproductasabase,whichisthenadaptedtosuittherequirementsofacustomer.EnterpriseResourcePlanning(ERP)systems,suchastheSAPsystem,arethebestexamplesofthisapproach.Here,alargeandcomplexsystemisadaptedforacompanybyincorporatinginformationaboutbusinessrulesandprocesses,reportsrequired,andsoon.AttributesofgoodsoftwareProductcharacteristicDescriptionMaintainabilitySoftwareshouldbewritteninsuchawaysothatitcanevolvetomeetthechangingneedsofcustomers.Thisisacriticalattributebecausesoftwarechangeisaninevitablerequirementofachangingbusinessenvironment.DependabilityandsecuritySoftwaredependabilityincludesarangeofcharacteristicsincludingreliability,securityandsafety.Dependablesoftwareshouldnotcausephysicaloreconomicdamageintheeventofsystemfailure.Malicioususersshouldnotbeabletoaccessordamagethesystem.EfficiencySoftwareshouldnotmakewastefuluseofsystemresourcessuchasmemoryandprocessorcycles.Efficiencythereforeincludesresponsiveness,processingtime,memoryutilisation,etc.AcceptabilitySoftwaremustbeacceptabletothetypeofusersforwhichitisdesigned.Thismeansthatitmustbeunderstandable,usableandcompatiblewithothersystemsthattheyuse.1.1.1SoftwareengineeringDefinition:anengineeringdisciplinethatisconcernedwithallaspectsofsoftwareproductionfromtheearlystagesofsystemspecificationthroughtomaintainingthesystemafterithasgoneintouse.Twokeyphases:Engineeringdiscipline
Engineersmakethingswork.Theyapplytheories,methods,andtoolswheretheseareappropriate.Engineersalsorecognizethattheymustworktoorganizationalandfinancialconstraints.Allaspectsofsoftwareproduction
Softwareengineeringisnotjustconcernedwiththetechnicalprocessesofsoftwaredevelopment.Italsoincludesactivitiessuchassoftwareprojectmanagementandthedevelopmentoftools,methods,andtheoriestosupportsoftwareproduction.WhysoftwareengineeringisimportantIndividualsandsocietyrelyonadvancedsoftwaresystems.Weneedtobeabletoproducereliableandtrustworthysystemseconomicallyandquickly.Itisusuallycheaper,inthelongrun,tousesoftwareengineeringmethodsandtechniquesforsoftwaresystemsratherthanjustwritetheprogramsasifitwasapersonalprogrammingproject.Formosttypesofsystems,themajorityofcostsarethecostsofchangingthesoftwareafterithasgoneintouse.SoftwareprocessAsoftwareprocessisasequenceofactivitiesthatleadstotheproductionofasoftwareproduct.Fourfundamentalactivitiescommontosoftwareprocesses.Softwarespecification,wherecustomersandengineersdefinethesoftwarethatistobeproducedandtheconstraintsonitsoperationSoftwaredevelopment,wherethesoftwareisdesignedandprogrammed.Softwarevalidation,wherethesoftwareischeckedtoensurethatitiswhatthecustomerrequires.Softwareevolution,wherethesoftwareismodifiedtoreflectchangingcustomerandmarketrequirements.1.1.2SoftwareengineeringdiversityNouniversalsoftwareengineeringmethodsandtechniquesthataresuitableforallsystemsandallcompanies.Themostsignificantfactorindeterminingwhichsoftwareengineeringmethodstobeusedistheapplicationtypethatisbeingdeveloped.Stand-aloneapplications
CADprograms,etc.Interactivetransaction-basedapplicationsEmbeddedcontrolsystems
SoftwareinmobilephoneBatchprocessingsystemsPeriodicbillingsystemsEntertainmentsystemsSystemsformodelingandsimulationDatacollectionsystemsSystemofsystemsSoftwareEngineeringfundamentalsTheyshouldbedevelopedusingamanagedandunderstooddevelopmentprocess.Dependabilityandperformanceareimportantforalltypesofsystems。Understandingandmanagingthesoftwarespecificationandrequirements(whatthesoftwareshoulddo)areimportant.Youshouldmakeaseffectiveuseaspossibleofexistingresources.1.1.3SEandtheWebThedevelopmentoftheWorldWideWebhashadaprofoundeffectonallofourlives.Thesoftwarewasdeployedonawebserver.Thismadeitmuchcheapertochangeandupgradethesoftware.Thenextstageinthedevelopmentofweb-basedsystemswasthenotionofwebservices.Thenotionof‘softwareasaservice’hasbeendeveloped.Ithasbeenproposedthatsoftwarewillrunon‘computingclouds’thatareaccessedovertheInternet.Theadventofthewebhasledtoasignificantchangeinthewaythatbusinesssoftwareisorganized.ChangesofWeb-basedsystemsareengineeredSoftwarereusehasbecomethedominantapproachforconstructingweb-basedsystems.Itisnowgenerallyrecognizedthatitisimpracticaltospecifyalltherequirementsforsuchsystemsinadvance.Userinterfacesareconstrainedbythecapabilitiesofwebbrowsers.Webformswithlocalscriptingaremorecommonlyused.Applicationinterfacesonweb-basedsystemsareoftenpoorer.1.2SoftwareEngineeringethicsSoftwareengineeringiscarriedoutwithinasocialandlegalframework.thereareareaswherestandardsofacceptablebehaviorarenotboundbylawsbutbythemoretenuousnotionofprofessionalresponsibility.Someoftheseare:Confidentiality
Youshouldnormallyrespecttheconfidentialityofyouremployersorclientsirrespectiveofwhetherornotaformalconfidentialityagreementhasbeensigned.Competence
Youshouldnotmisrepresentyourlevelofcompetence.IntellectualpropertyrightsYoushouldbeawareoflocallawsgoverningtheuseofintellectualpropertysuchaspatentsandcopyright.ComputermisuseYoushouldnotuseyourtechnicalskillstomisuseotherpeople’scomputers.1.3CaseStudyExamplesfromthreedifferenttypesofsystemsareusedthroughoutthebook.Anappropriateexampleisusedwhendiscussingconceptssuchassafetyanddependability,systemmodeling,reuse,etc.AnembeddedsystemThisisasystemwherethesoftwarecontrolsahardwaredeviceandisembeddedinthatdevice.AninformationsystemThisisasystemwhoseprimarypurposeistomanageandprovideaccesstoadatabaseofinformation.Asensor-baseddatacollectionsystemThisisasystemwhoseprimarypurposeistocollectdatafromasetofsensorsandprocessthatdatainsomeway.Case1:AninsulinpumpcontrolsystemInsulinpumphardwareAninsulinpumpcontrolsystemActivitymodeloftheinsulinpumpAninsulinpumpcontrolsystemTwoessentialhigh-levelrequirementsthatthissystemmustmeet:Thesystemshallbeavailabletodeliverinsulinwhenrequired.ThesystemshallperformreliablyanddeliverthecorrectamountofinsulintocounteractthecurrentlevelofbloodsugarCase2:ApatientinformationsystemformentalhealthcareTheMHC-PMS(MentalHealthCare-PatientManagementSystem)isaninformationsystemthatisintendedforuseinclinics.Ithastwooverallgoals:Togeneratemanagementinformationthatallowshealthservicemanagerstoassessperformanceagainstlocalandgovernmenttargets.Toprovidemedicalstaffwithtimelyinformationtosupportthetreatmentofpatients.Case2:OrganizationofMHC-PMSCase2:UsersofMHC-PMSUsersofthesystemincludeclinicalstaffsuchasdoctors,nurses,andhealthvisitors.Nonmedicalusersincludereceptionistswhomakeappointments,medicalrecordsstaffwhomaintaintherecordssystem,andadministrativestaffwhogeneratereports.Thesystemisusedtorecordinformationaboutpatients(name,address,age,nextofkin,etc.),consultations(date,doctorseen,subjectiveimpressionsofthepatient,etc.),conditions,andtreatments.Reportsaregeneratedatregularintervalsformedicalstaffandhealthauthoritymanagers.Case2:KeyfeaturesofMHC-PMSIndividualcaremanagementClinicianscancreaterecordsforpatients,edittheinformationinthesystem,viewpatienthistory,etc.PatientmonitoringThesystemregularlymonitorstherecordsofpatientsthatareinvolvedintreatmentandissueswarningsifpossibleproblemsaredetected.AdministrativereportingThesystemgeneratesmonthlymanagementreportsshowingthenumberofpatientstreatedateachclinic,thenumberofpatientswhohaveenteredandleftthecaresystem,numberofpatientssectioned,thedrugsprescribedandtheircosts,etc.Case3:AwildernessweatherstationWeatherstationcollectdatafromasetofinstrumentsthatmeasuretemperatureandpressure,sunshine,rainfall,windspeed,andwinddirection.Wildernessweatherstationsarepartofalargersystem,whichisaweatherinformationsystemthatcollectsdatafromweatherstationsandmakesitavailabletoothersystemsforprocessing.Case3:AwildernessweatherstationTheweatherstationsystemThisisresponsibleforcollectingweatherdata,carryingoutsomeinitialdataprocessing,andtransmittingittothedatamanagementsystem.ThedatamanagementandarchivingsystemThissystemcollectsthedatafromallofthewildernessweatherstations,carriesoutdataprocessingandanalysis,andarchivesthedatainaformthatcanberetrievedbyothersystems.ThestationmaintenancesystemThissystemcancommunicatebysatellitewithallwildernessweatherstationstomonitorthehealthofthesesystemsandprovidereportsofproblems.Itcanupdatetheembeddedsoftwareinthesesystems.Intheeventofsystemproblems,thissystemcanalsobeusedtoremotelycontrolawildernessweathersystem.Case3:AwildernessweatherstationEachweatherstationisbattery-poweredandmustbeentirelyself-contained—therearenoexternalpowerornetworkcablesavailable.Allcommunicationsarethrougharelativelyslow-speedsatellitelinkandtheweatherstationmustincludesomemechanism(solarorwindpower)tochargeitsbatteries.Thestationsoftwareisthereforenotjustconcernedwithdatacollection.Itmustalso:Monitortheinstruments,power,andcommunicationhardwareandreportfaultstothemanagementsystem.Managethesystempower,ensuringthatbatteriesarechargedwhenevertheenvironmentalconditionspermitbutalsothatgeneratorsareshutdowninpotentiallydamagingweatherconditions,suchashighwind.Allowfordynamicreconfigurationwherepartsofthesoftwarearereplacedwithnewversionsandwherebackupinstrumentsareswitchedintothesystemintheeventofsystemfailure.KeypointsofChapter1Softwareengineeringisanengineeringdisciplinethatisconcernedwithallaspectsofsoftwareproduction.Softwareisnotjustaprogramorprogramsbutalsoincludesdocumentation.Essentialsoftwareproductattributesaremaintainability,dependability,security,efficiency,andacceptability.Thesoftwareprocessincludesalloftheactivitiesinvolvedinsoftwaredevelopment.Thehighlevelactivitiesofspecification,development,validation,andevolutionarepartofallsoftwareprocesses.Thefundamentalnotionsofsoftwareengineeringareuniversallyapplicabletoalltypesofsystemdevelopment.Thesefundamentalsincludesoftwareprocesses,dependability,security,requirements,andreuse.KeypointsofChapter1Therearemanydifferenttypesofsystemsandeachrequiresappropriatesoftwareengineeringtoolsandtechniquesfortheirdevelopment.Therearefew,ifany,specificdesignandimplementationtechniquesthatareapplicabletoallkindsofsystems.Thefundamentalideasofsoftwareengineeringareapplicabletoalltypesofsoftwaresystems.Thesefundamentalsincludemanagedsoftwareprocesses,softwaredependabilityandsecurity,requirementsengineering,andsoftwarereuse.Softwareengineershaveresponsibilitiestotheengineeringprofessionandsociety.Theyshouldnotsimplybeconcernedwithtechnicalissues.Professionalsocietiespublishcodesofconductthatsetoutthestandardsofbehaviorexpectedoftheirmembers.Exercise1.1.Explainwhyprofessionalsoftwareisnotjusttheprogramsthataredevelopedforacustomer.1.2.Whatisthemostimportantdifferencebetweengenericsoftwareproductdevelopmentandcustomsoftwaredevelopment?Whatmightthismeaninpracticeforusersofgenericsoftwareproducts?1.3.Whatarethefourimportantattributesthatallprofessionalsoftwareshouldhave?Suggestfourotherattributesthatmaysometimesbesignificant.1.4.Apartfromthechallengesofheterogeneity,businessandsocialchange,andtrustandsecurity,identifyotherproblemsandchallengesthatsoftwareengineeringislikelytofaceinthe21stcentury(Hint:thinkabouttheenvironment).1.5.Basedonyourownknowledgeofsomeoftheapplicationtypesdiscussedinsection1.1.2,explain,withexamples,whydifferentapplicationtypesrequirespecializedsoftwareengineeringtechniquestosupporttheirdesignanddevelopment.Exercise1.6.Explainwhytherearefundamentalideasofsoftwareengineeringthatapplytoalltypesofsoftwaresystems.1.7.ExplainhowtheuniversaluseoftheWebhaschangedsoftwaresystems.1.8.Discusswhetherprofessionalengineersshouldbecertifiedinthesamewayasdoctorsorlawyers.1.9.ForeachoftheclausesintheACM/IEEECodeofEthicsshowninFigure1.3,suggestanappropriateexamplethatillustratesthatclause.1.10.Tohelpcounterterrorism,manycountriesareplanningorhavedevelopedcomputersystemsthattracklargenumbersoftheircitizensandtheiractions.Clearlythishasprivacyimplications.Discusstheethicsofworkingonthedevelopmentofthistypeofsystem.NationalEngineeringCenterforCADChapter2
SoftwareProcessHuazhongUniversityofScienceandTechnologyNationalEngineeringCenterforCADLiuQinghualiuqh@Chapter2:SoftwareprocessObjectives:Introduceyoutotheideaofasoftwareprocess—acoherentsetofactivitiesforsoftwareproduction.Understandtheconceptsofsoftwareprocessesandsoftwareprocessmodels;Beintroducedtothreegenericsoftwareprocessmodelsandwhentheymightbeused;Knowaboutthefundamentalprocessactivitiesofsoftwarerequirementsengineering,softwaredevelopment,testing,andevolution;Understandwhyprocessesshouldbeorganizedtocopewithchangesinthesoftwarerequirementsanddesign;UnderstandhowtheRationalUnifiedProcessintegratesgoodsoftwareengineeringpracticetocreateadaptablesoftwareprocesses.Contents2.1Softwareprocessmodels2.2Processactivities2.3Copingwithchange2.4TheRationalUnifiedProcessFouractivitiesofsoftwareprocessmodelTherearemanydifferentsoftwareprocessesbutallmustincludefouractivitiesthatarefundamentaltosoftwareengineering:1.Softwarespecification
Thefunctionalityofthesoftwareandconstraintsonitsoperationmustbedefined.2.SoftwaredesignandimplementationThesoftwaretomeetthespecificationmustbeproduced.3.SoftwarevalidationThesoftwaremustbevalidatedtoensurethatitdoeswhatthecustomerwants.4.SoftwareevolutionThesoftwaremustevolvetomeetchangingcustomerneeds.SoftwareprocessmodelsAsoftwareprocessmodelisasimplifiedrepresentationofasoftwareprocess.Eachprocessmodelrepresentsaprocessfromaparticularperspective,andthusprovidesonlypartialinformationaboutthatprocess.Inthissection,anumberofverygeneralprocessmodelsisintroduced(sometimescalled‘processparadigms’)andarepresentedfromanarchitecturalperspective.Thatis,weseetheframeworkoftheprocessbutnotthedetailsofspecificactivities.ThewaterfallmodelThewaterfallmodelThewaterfallmodelisanexampleofaplan-drivenprocess—inprinciple,youmustplanandschedulealloftheprocessactivitiesbeforestartingworkonthem.Inprinciple,thewaterfallmodelshouldonlybeusedwhentherequirementsarewellunderstoodandunlikelytochangeradicallyduringsystemdevelopment.Animportantvariantofthewaterfallmodelisformalsystemdevelopment.Formaldevelopmentprocesses,suchasthatbasedontheBmethodareparticularlysuitedtothedevelopmentofsystemsthathavestringentsafety,reliability,orsecurityrequirements.CleanroomsoftwareengineeringOriginallydevelopedbyIBMIntheCleanroomprocesseachsoftwareincrementisformallyspecifiedandthisspecificationistransformedintoanimplementation.Softwarecorrectnessisdemonstratedusingaformalapproach.Thereisnounittestingfordefectsintheprocessandthesystemtestingisfocusedonassessingthesystem’sreliability.TheobjectiveoftheCleanroomprocessiszero-defectssoftwaresothatdeliveredsystemshaveahighlevelofreliability.IncrementaldevelopmentThesystemisdevelopedasaseriesofversions(increments),witheachversionaddingfunctionalitytothepreviousversion.IncrementaldevelopmentIncrementaldevelopmentisbasedontheideaofdevelopinganinitialimplementation,exposingthistousercommentandevolvingitthroughseveralversionsuntilanadequatesystemhasbeendeveloped.Specification,development,andvalidationactivitiesareinterleavedratherthanseparate,withrapidfeedbackacrossactivities.Incrementalsoftwaredevelopment,whichisafundamentalpartofagileapproaches,isbetterthanawaterfallapproachformostbusiness,e-commerce,andpersonalsystems.Incrementaldevelopment:benefitsIncrementaldevelopmenthasthreeimportantbenefits,comparedtothewaterfallmodel:1.Thecostofaccommodatingchangingcustomerrequirementsisreduced.Theamountofanalysisanddocumentationthathastoberedoneismuchlessthanisrequiredwiththewaterfallmodel.2.Itiseasiertogetcustomerfeedbackonthedevelopmentworkthathasbeendone.Customerscancommentondemonstrationsofthesoftwareandseehowmuchhasbeenimplemented.3.Morerapiddeliveryanddeploymentofusefulsoftwaretothecustomerispossible,evenifallofthefunctionalityhasnotbeenincluded.
CustomersareabletouseandgainvaluefromthesoftwareearlierthanispossiblewithawaterfallprocessProblemswithIncrementaldevelopmentFromamanagementperspective,theincrementalapproachhastwoproblems:Theprocessisnotvisible.Managersneedregulardeliverablestomeasureprogress.Ifsystemsaredevelopedquickly,itisnotcost-effectivetoproducedocumentsthatreflecteveryversionofthesystem.Systemstructuretendstodegradeasnewincrementsareadded.Unlesstimeandmoneyisspentonrefactoringtoimprovethesoftware,regularchangetendstocorruptitsstructure.Incorporatingfurthersoftwarechangesbecomesincreasinglydifficultandcostly.Reuse-orientedsoftwareengineeringThesystemdevelopmentprocessfocusesonintegratingexistedcomponentsintoasystemratherthandevelopingthemfromscratch.Theintermediatestagesinareuse-orientedprocessaredifferent.Thesestagesare:1Componentanalysis
Giventherequirementsspecification,asearchismadeforcomponentstoimplementthatspecification.2RequirementsmodificationTherequirementsareanalyzedusinginformationaboutthecomponentsthathavebeendiscovered.3SystemdesignwithreuseTheframeworkofthesystemisdesignedoranexistingframeworkisreused.4DevelopmentandintegrationSoftwarethatcannotbeexternallyprocuredisdeveloped,andthecomponentsandCOTS(Commercialof-the-shelfsystems)areintegratedtocreatethenewsystem.Reuse-orientedsoftwareengineeringTherearethreetypesofsoftwarecomponentthatmaybeusedinareuse-orientedprocess:1.Webservicesthataredevelopedaccordingtoservicestandardsandwhichareavailableforremoteinvocation.2.Collectionsofobjectsthataredevelopedasapackagetobeintegratedwithacomponentframeworksuchas.NETorJ2EE.3.Stand-alonesoftwaresystemsthatareconfiguredforuseinaparticularenvironment.SoftwarecomponentsReuse-orientedsoftwareengineeringhastheobviousadvantageofreducingtheamountofsoftwaretobedevelopedandsoreducingcostandrisks.Itusuallyalsoleadstofasterdeliveryofthesoftware.Requirementscompromisesareinevitableandthismayleadtoasystemthatdoesnotmeettherealneedsofusers.Somecontroloverthesystemevolutionislostasnewversionsofthereusablecomponentsarenotunderthecontroloftheorganizationusingthem.Prosandco
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 制梁勞務合同范例
- 信貸資產(chǎn)信托合同范本
- 乙醇燃料的成本管理和降本增效
- 不帶司機租車合同范本
- 全款買車銷售合同范本
- 兼職模特合同范例
- 冷庫設(shè)備購銷合同范本
- 農(nóng)村承包魚塘經(jīng)營合同范例
- 電影制片人聘用合同范本
- 徐州白云區(qū)門面出租經(jīng)營合同范本
- 2025屆西藏林芝一中高三第二次診斷性檢測英語試卷含解析
- 中國傳統(tǒng)文化非遺文化中國剪紙介紹2
- 藥企銷售總經(jīng)理競聘
- 開封市第一屆職業(yè)技能大賽健康照護項目技術(shù)文件(國賽)
- 飲酒與糖尿病
- 公路電子收費系統(tǒng)安裝合同范本
- 醫(yī)院培訓課件:《傷口評估與測量》
- 期末試卷(試題)-2024-2025學年四年級上冊數(shù)學滬教版
- 《第一單元口語交際:即興發(fā)言》教案-2023-2024學年六年級下冊語文統(tǒng)編版
- 情侶自愿轉(zhuǎn)賬贈與協(xié)議書范本
- 綜合實踐項目 制作水族箱飼養(yǎng)淡水魚 教學設(shè)計-2024-2025學年魯科版生物六年級上冊
評論
0/150
提交評論