软件工程专业英语-Software Reengineering_第1页
软件工程专业英语-Software Reengineering_第2页
软件工程专业英语-Software Reengineering_第3页
软件工程专业英语-Software Reengineering_第4页
软件工程专业英语-Software Reengineering_第5页
已阅读5页,还剩43页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

我们毕业啦其实是答辩的标题地方软件工程专业英语SOFTWAREENGINEERINGESSENTIALS22.1SOFTWAREENGINEERING2.2SOFTWAREREENGINEERING2.3

REVERSEENGINEERINGSUMMARYCHAPTER2

SOFTWAREREENGINEERING2.1SOFTWAREENGINEERING3Inthelongperiodofpracticeinbuildingsoftware,softwaredevelopershavedrawnaconclusion:softwareinallofitsformsandacrossallofitsapplicationdomainsshouldbeengineered.4SoftwareEngineeringOverviewSoftwareProcessModelPhasesofSoftwareDevelopmentMethodologyofSoftwareDevelopment1.Whatissoftwareengineering?Softwareengineeringistheestablishmentanduseofsoundengineeringprinciplesinordertoobtaineconomicallysoftwarethatisreliableandworksefficientlyonrealmachines.SoftwareEngineering:(1)Theapplicationofasystematic,disciplined,andquantifiableapproachtothedevelopment,operation,andmaintenanceofsoftware;thatis,theapplicationofengineeringtosoftware.(2)Thestudyofapproachesasin(1).------TheIEEEhasdevelopedamorecomprehensivedefinition2.OriginofsoftwareengineeringInordertoreducetheinfluencesofsoftwarecrises,thecomputerscientistsdiscussedthesoftwarecrisesproblemsatinternationalconferenceinGermanin1968,andthenameof“SoftwareEngineering”wasfirstputforwardandadopted.Fromthenon,SoftwareEngineering,asanewengineeringdiscipline,wasborn.3.Whatisalifecycleofsoftware?Theperiodoftimethatisneededtocreatenewsoftware,iscalledthelifecycleofsoftware,whichstartsfromthetimeofproblemdefinition,thendevelopment,deploymentandmaintenance,tillthemomentofretirement.

4.SoftwareprocessAsoftwareprocessisacollectionofactivities,actions,andtasksperformedwhensoftwareisbeingbuilt.Anactivitystrivestoachieveabroadobjective(e.g.,communicationwithusers)andisappliedregardlessoftheapplicationdomain,sizeoftheproject,complexityoftheeffort,ordegreeofrigorwithwhichsoftwareengineeringistobeapplied.Anaction(e.g.,architecturaldesign)encompassesasetoftasksthatproduceamajorworkproduct(e.g.,anarchitecturaldesignmodel).Ataskfocusesonasmall,butwell-definedobjective(e.g.,conductingaunittest)thatproducesatangibleoutcome.2.1.2SoftwareProcessModelTherearelotsofsoftwareprocessmodels,including

waterfall,

prototyping,

iterative,incrementaldevelopment,

spiraldevelopment,

rapidapplicationdevelopment,

extremeprogramming

andvarioustypesof

agilemethodology.

ThewaterfallmodelTheIncrementalmodelTheSpiralmodelTheAgileprocessAvarietyofsoftwareprocessmodelshaveevolvedovertheyears,eachwithitsownrecognizedstrengthsandweaknesses.Onesoftwaredevelopmentprocessmodelisnotnecessarilysuitableforusebyallprojects.Eachoftheavailableprocessmodelisbestsuitedtospecifickindsofprojects,basedonvarioustechnical,organizationalandteamconsiderations.2.1.3PhasesofSoftwareDevelopmentSoftwaredevelopmentlifecycleSoftwaredevelopmentlifecycle,usuallyreferredtoasSDLC,isanoutlineofaprocessthathelpsdevelopsuccessfullysoftwaresystems.AnSDLCisasplittingofsoftwaredevelopmentworkintodistinctphase(orstages)containingactivitieswiththeintentofbetterplanningandmanagement.Thesephasesencompassplanning,analysis,design,implementationandmaintenancephases.Theimportantthingforconstructingasystemistohaveaplan.Theprocessofplanningandbuildinganapplicationsystemarecalledsystemsanalysisanddesign.Thisprocessbeginswithplanningphase.PlanningphaseAnalysisphaseDesignphaseImplementationphaseMaintenancephase1.PlanningphaseThegoalofthisperiodistocreateaprojectdevelopmentplan.So,theactivitiesincludedintheplanningphaseareshownasthefollowing:AssembletheprojectteamJustifyprojectChoosedevelopmentmethodologyDevelopaprojectscheduleProduceaprojectdevelopmentplan2.AnalysisphaseThegoaloftheanalysisphaseistoproducealistofrequirementsforaneworrevisedinformationsystem.Intheanalysisphase,theprojectteamdetermineswhatthenewsystemmustdo.Aseriesofactivitiesfortheanalysisphaseareshownasthefollowing:StudythecurrentsystemDeterminesystemrequirementsWriterequirementsreport

3.DesignphaseDuringthedesignphaseofSDLC,developersmustfigureouthowthenewsystemwillfulfilltherequirementsspecifiedinthesystemrequirementsreport.Tasksforthedesignphasearelistedinthefollowing:IdentifypotentialsolutionsEvaluatesolutionsandselectthebestSelecthardwareandsoftwareDevelopapplicationspecificationsObtainapprovaltoimplementthenewsystem

4.ImplementationphaseInimplementationphase,theprojectteamsupervisesthetasksnecessarytoconstructthenewsoftwaresystem.Thetasksthattakeplaceinthisphasecanincludeanyofthoseshowninthenext:Purchaseandinstallhardwareand/orsoftwareCreateapplicationsTestapplicationsFinalizedocumentationTrainusersConvertdataConverttonewsystem5.MaintenancephaseDuringthemaintenancephase,thegoalsareday-to-dayoperationofsystem,makingmodificationstoimproveperformance,andcorrectingproblems.Theactivitiesduringthephaseshouldensurethatthesystemfunctionsaswellaspossible.Themainactivitiesinvolvethefollowing:OperateequipmentMakebackupsProvidehelptousersFixbugsOptimizespeedandsecurityRevisesoftwareasnecessarytomeetbusinessneeds2.1.4MethodologyofSoftwareDevelopmentAsoftwaredevelopmentteamtypicallydevelopsasoftwaresystemaccordingtoaspecificmethodologyandasetofrelateddevelopmenttools.Thestructuredmethodologyandtheobject-orientedmethodologyarethetwodistinguishedmethodologiesinpractice.Thestructuredmethodologyisconsideredasthetypicalone.Itfocusesontheprocessesofasoftwaresystem.Theobject-orientedmethodologytreatsaninformationsystemasacollectionofobjectsthatinteractwitheachothertoaccomplishspecifictasks.191.Whatissoftwareengineering?2.Whatisasoftwareprocessmodel?Explaintherolesofsoftwareprocessmodelindevelopmentactivities.3.Howmanysoftwareprocessmodelshavebeendiscussedinthischapter?4.

Howmanyphasesarethereinthesoftwaredevelopmentlifecycle?Describethetasksofeachphase.ConceptCheck202.2SOFTWAREREENGINEERINGManysoftwaresystemstendtogrowlargerwithtime,andbecomelessstructuredwithchangesandlessunderstandablewithstuffturnover.Astheresult,theapplicationsbecomeunstable.Yettheapplicationsmustcontinuetoevolve.Ontheotherside,bothmaintenanceoftheinterfacesandtheimplementationhavenontrivialpercentagecostsoftheIT-budget.Whattodo?Infact,thebroadeningemphasisonsoftwarereengineeringhasbeenspawnedbysoftwaremaintenanceproblems.Reengineeringalegacysoftwaresystemtosupportnew,moderntechnologiesinsteadofoldonesisnotaneasytask,especiallyforlargesystemswithcomplexarchitecture.212.2SOFTWAREREENGINEERINGOriginofReengineeringASoftwareReengineeringModelSoftwareReengineeringActivities2.2.1OriginofReengineeringWhatisreengineering?Reengineering,alsoknownasbothrenovationandreclamation,is

theexaminationandalterationofasoftwaresystemtoreconstituteitinanewformandthesubsequentimplementationofthenewform.Theactivitiesofreengineeringgenerallyincludesinventoryanalysis,reverseengineering,forwardengineering,documentationrestructuring,coderestructuringanddatarestructuring.ThetwohistoricreengineeringinitiatorsTheY2Kproblem:Formanycompaniesthiswasthefirsttimetheyhadtodealwithreengineeringmechanisms.Y2Kalonecreatedamulti-billionreengineeringmarketandignitedtheoffshoresoftwareindustryinIndiaandothercountries.TheintroductionoftheEURO:TheintroductionoftheEUROcreatedanotherhugereengineeringrequest,mainlyintheEuropeanfinanceindustry.Twosignificantchangeshadtobeaddressednearlyatthesametime,theintroductionoftheEUROtobecompletedbyJanuary1,1999andtheY2KproblemtoberesolvedatlatestonJanuary1,2000.2.2.2ASoftwareReengineeringModelReengineeringisarebuildingactivity.Asoftwarereengineeringprocessmodeldefinessixactivities,showninFigure2-3.2.2.3SoftwareReengineeringActivitiesInventoryanalysisDocumentrestructuringReverseengineeringCoderestructuringDatarestructuringForwardengineering1.InventoryanalysisEverysoftwareorganizationshouldhaveaninventoryofallapplications.Theinventorycanbenothingmorethanaspreadsheetmodelcontaininginformationthatprovidesadetaileddescription(e.g.,size,age,businesscriticality)ofeveryactiveapplication.Bysortingthisinformationaccordingtobusinesscriticality,longevity,currentmaintainabilityandsupportability,andotherlocallyimportantcriteria,candidatesforreengineeringappear.Resourcescanthenbeallocatedtocandidateapplicationsforreengineeringwork.Itisimportanttonotethattheinventoryshouldberevisitedonaregularcycle.Thestatusofapplications(e.g.,businesscriticality)canchangeasafunctionoftime,andasaresult,prioritiesforreengineeringwillshift.2.DocumentrestructuringCreatingdocumentationisfartootimeconsuming.Ifthesystemworks,youmaychoosetolivewithwhatyouhave.Insomecases,thisisthecorrectapproach.Documentationmustbeupdated,butyourorganizationhaslimitedresources.You’llusea“documentwhentouched”approach.Itmaynotbenecessarytofullyredocumentanapplication.Rather,thoseportionsofthesystemthatarecurrentlyundergoingchangearefullydocumented.Overtime,acollectionofusefulandrelevantdocumentationwillevolve.Thesystemiscriticalbusinessandmustbefullyredocumented.Eveninthiscase,anintelligentapproachistoparedocumentationtoanessentialminimum.3.ReverseengineeringThetermreverseengineeringhasitsoriginsinthehardwareworld.Reverseengineeringforsoftwareisquitesimilar.Inmostcases,however,theprogramtobereverseengineeredisnotacompetitor’s.Rather,itisthecompany’sownwork(oftendonemanyyearsearlier).The“secrets”tobeunderstoodareobscurebecausenospecificationwaseverdeveloped.Therefore,reverseengineeringforsoftwareistheprocessofanalyzingaprograminanefforttocreatearepresentationoftheprogramatahigherlevelofabstractionthansourcecode.Reverseengineeringisaprocessofdesignrecovery.Reverseengineeringtoolsextractdata,architectural,andproceduraldesigninformationfromanexistingprogram.4.CoderestructuringThemostcommontypeofreengineering(actually,theuseofthetermreengineeringisquestionableinthiscase)iscoderestructuring.Somelegacysystemshavearelativelysolidprogramarchitecture,butindividualmoduleswerecodedinawaythatmakesthemdifficulttounderstand,test,andmaintain.Insuchcases,thecodewithinthesuspectmodulescanberestructured.Toaccomplishthisactivity,thesourcecodeisanalyzedusingarestructuringtool.Violationsofstructuredprogrammingconstructsarenotedandcodeisthenrestructured(thiscanbedoneautomatically)orevenrewritteninamoremodernprogramminglanguage.Theresultantrestructuredcodeisreviewedandtestedtoensurethatnoanomalieshavebeenintroduced.Internalcodedocumentationisupdated.5.DatarestructuringAprogramwithweakdataarchitecturewillbedifficulttoadaptandenhance.Infact,formanyapplications,informationarchitecturehasmoretodowiththelong-termviabilityofaprogramthanthesourcecodeitself.Datarestructuringisafull-scalereengineeringactivity.Inmostcases,datarestructuringbeginswithareverseengineeringactivity.Currentdataarchitectureisdissected,anddatamodelsaredefinedwhennecessary.Dataobjectsandattributesareidentified,andexistingdatastructuresarereviewedforquality.Whendatastructureisweak,thedataarereengineered.Becausedataarchitecturehasastronginfluenceonprogramarchitectureandthealgorithmsthatpopulateit,changestothedatawillinvariablyresultineitherarchitecturalorcode-levelchanges.6.ForwardengineeringForwardengineeringisthetraditionalprocessofmovingfromhigh-levelabstractionsandlogical,implementation-independentdesignstothephysicalimplementationofasystem.Forwardengineeringnotonlyrecoversdesigninformationfromexistingsoftwarebutusesthisinformationtoalterorreconstitutetheexistingsysteminanefforttoimproveitsoverallquality.Inmostcases,reengineeredsoftwarereimplementsthefunctionoftheexistingsystemandalsoaddsnewfunctionsand/orimprovesoverallperformance.ConceptCheckWhatissoftwarereengineering?Discussthetwotypicalreengineeringproblems.Whatkindsofactivitiesareincludedinasoftwarereengineeringmodel?Explainthemainreasonsthatmanycorporationsneedapragmaticstrategyforsoftwarereengineering.Discusstheroleofeachactivityincludedinasoftwarereengineeringmodel.332.3REVERSEENGINEERINGWhatisReverseEngineering?TheReverseEngineeringProcessReverseEngineeringtoUnderstandProcessingReverseEngineeringtoUnderstandDataReverseEngineeringUserInterfaces2.3.1WhatisReverseEngineering?Reverseengineeringistheprocessofanalyzingasubjectsystemto•Identifythesystem’scomponentsandtheirinterrelationships;•Createrepresentationsofthesysteminanotherformoratahigherlevelofabstraction.Reverseengineeringgenerallyinvolvesextractingdesignartifactsandbuildingorsynthesizingabstractionsthatarelessimplementation-dependent.Whilereverseengineeringofteninvolvesanexistingfunctionalsystemasitssubject,thisisnotarequirement.Youcanperformreverseengineeringstartingfromanylevelofabstractionoratanystageofthelifecycle.2.Keyobjectives1)Copewithcomplexity.2)Generatealternateviews.3)Recoverlostinformation.4)Detectsideeffects.5)Synthesizehigherabstractions.6)Facilitatereuse.2.3.2TheReverseEngineeringProcessInspanningthelife-cyclestages,reverseengineeringcoversabroadrangestartingfromtheexistingimplementation,recapturingorrecreatingthedesign,anddecipheringtherequirementsactuallyimplementedbythesubjectsystem.Therearemanysubareasofreverseengineering.Twosubareasthatarewidelyreferredtoareredocumentationanddesignrecovery.ThereverseengineeringprocessisrepresentedinFigure2-4.Beforereverseengineeringactivitiescancommence,unstructured(“dirty”)sourcecodeisrestructuredsothatitcontainsonlythestructuredprogrammingconstructs.Thismakesthesourcecodeeasiertoreadandprovidesthebasisforallthesubsequentreverseengineeringactivities.Thecoreofreverseengineeringisanactivitycalledextractabstractions.Youmustevaluatetheoldprogramandfromthe(oftenundocumented)sourcecode,developameaningfulspecificationoftheprocessingthatisperformed,theuserinterfacethatisapplied,andtheprogramdatastructuresordatabasethatisused.

Figure2-4Thereverseengineeringprocess2.3.3ReverseEngineeringtoUnderstandProcessingReverseengineeringtounderstandprocessingbeginswithanattempttounderstandandthenextractproceduralabstractionsrepresentedbythesourcecode.Tounderstandproceduralabstractions,thecodeisanalyzedatvaryinglevelsofabstraction:system,program,component,pattern,andstatement.Theoverallfunctionalityoftheentireapplicationsystemmustbeunderstoodbeforemoredetailedreverseengineeringworkoccurs.Thisestablishesacontextforfurtheranalysisandprovidesinsightintointeroperabilityissuesamongapplicationswithinthesystem.2.3.4ReverseEngineeringtoUnderstandDataReverseengineeringofdataoccursatdifferentlevelsofabstractionandisoftenthefirstreengineeringtask.Attheprogramlevel,internalprogramdatastructuresmustoftenbereverseengineeredaspartofanoverallreengineeringeffort.Atthesystemlevel,globaldataareoftenreengineeredtoaccommodatenewdatabasemanagementparadigms.Reverseengineeringofthecurrentglobaldatastructuressetsthestagefortheintroductionofanewsystem-widedatabase.2.3.4ReverseEngineeringtoUnderstandDataDatabasereengineering,consistsoftransformingalegacydatabaseaccordingtonewtechnicalrequirements,whilekeepingtheinformationcontentsunchanged.Substitutingamoderndatamanagementsystem(relationalDBMSforinstance)foranoutdatedmanager(typicallystandardfilemanager),orimprovingthelogicalschematogainbetterperformancearepopularscenarios.Regardlessofitslogicalorganizationandphysicalstructure,adatabaseallowsthedefinitionofdataobjectsandsupportssomemethodforestablishingrelationshipsamongtheobjects.Therefore,reengineeringonedatabaseschemaintoanotherrequiresanunderstandingofexistingobjectsandtheirrelationships.2.3.4ReverseEngineeringtoUnderstandDataTypically,theprocessthatconvertingalegacysystemtoamoderndatabasetechnology,comprisesthefollowingthreemainsteps:(1)Databaseschemaconversion:thelegacydatabaseschemaistranslatedintoanequivalentschemaexpressedinthetargettechnology.(2)Dataconversion:thedatabasecontentsaremigratedfromthelegacydatabasetothenewone.Thisstepconsistsofaschema-drivenETLprocess.(3)Programconversion:thelegacyprogramsaremodifiedsothattheyaccessthenewdatabaseinsteadofthelegacydata.Inthescenariostudied,thefunctionalities,theprogramminglanguageandtheuserinterfacearekeptunchanged.Thisconversionstepisgenerallyacomplexproce

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论