版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
軟件工程(研究生)全冊(cè)配套課件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等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年度學(xué)校校園打印店經(jīng)營租賃合同3篇
- 2024年林業(yè)生態(tài)工程建筑合同
- 2024版大米產(chǎn)業(yè)技術(shù)研究與應(yīng)用推廣合同3篇
- 2024年版醫(yī)院物業(yè)管理合同3篇
- 2024版出租車智能調(diào)度系統(tǒng)服務(wù)合同3篇
- 2024年度專用:施工合同簽訂詳細(xì)步驟與安全文明施工管理3篇
- 2024年新型智慧社區(qū)停車場(chǎng)使用權(quán)租賃合同3篇
- 2024年度地鐵隧道施工吊車租賃合同及吊機(jī)操作培訓(xùn)3篇
- 2024年度保險(xiǎn)業(yè)務(wù)合作合同協(xié)議書2篇
- 2024年度三方合作協(xié)議:城市軌道交通項(xiàng)目合作開發(fā)合同3篇
- 2024年度公司各級(jí)安全生產(chǎn)責(zé)任制考核細(xì)則表
- 2024屆高考專題復(fù)習(xí):下定義+課件
- T/CEC 143-2017 超高性能混凝土電桿完整
- 京瓷哲學(xué)78條文字
- 2024年國家工作人員學(xué)法考法知識(shí)考試題庫500題(含答案)
- 對(duì)武漢市臨床護(hù)生從事老年社區(qū)護(hù)理工作意愿及影響因素的調(diào)查分析
- MOOC 社會(huì)心理學(xué)-浙江大學(xué) 中國大學(xué)慕課答案
- MOOC 國際交流學(xué)術(shù)英文寫作-湖南大學(xué) 中國大學(xué)慕課答案
- JJG 692-2010無創(chuàng)自動(dòng)測(cè)量血壓計(jì)
- MOOC 電磁場(chǎng)與電磁波理論-南京郵電大學(xué) 中國大學(xué)慕課答案
- 2024年度-養(yǎng)豬技術(shù)(教案)
評(píng)論
0/150
提交評(píng)論