版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
我们毕业啦其实是答辩的标题地方软件工程专业英语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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 研究教学工作计划集锦
- 聊城大学《版式设计》2021-2022学年第一学期期末试卷
- 辽宁科技大学《环境设计理论》2021-2022学年第一学期期末试卷
- 丽水学院《算法分析与设计》2023-2024学年第一学期期末试卷
- 丽江文化旅游学院《数据分析语言程序设计》2023-2024学年第一学期期末试卷
- 昆明理工大学津桥学院《舞蹈基础1》2021-2022学年第一学期期末试卷
- 昆明理工大学《文学理论与批评》2021-2022学年第一学期期末试卷
- 昆明理工大学《景观设计(1)(居住景观)》2021-2022学年第一学期期末试卷
- 昆明理工大学《半导体物理》2021-2022学年第一学期期末试卷
- 髋臼骨折的临床特征
- 市场主体迁移申请书
- 园林绿化种子进场检验记录
- 2022年奇石协会会长讲话稿模板
- 国开作业《公共部门人力资源管理》形考任务4:撰写课程学习总结(第1-9章权重25%)参考033
- 思想道德与法治课件:第六章 第四节 自觉尊法学法守法用法
- 文艺复兴时期的美术教案
- 酒店装饰装修工程验收表
- 南方地区 同步教案 初中地理粤人版八年级下册(2022年)
- 五人相声好好好相声《好好好》台词
- 2022年广西南宁市中考数学试卷及解析
- 围棋入门课件(专业应用)
评论
0/150
提交评论