版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
我们毕业啦其实是答辩的标题地方软件工程专业英语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. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 个人房屋转让合同协议书范本大全
- 二零二五年度智能家居墙面粉刷及安防系统合同
- 二零二五年度石材加工厂租赁合同(附石材研发合作及市场推广)
- 二零二五年度汽车美容店员工劳动合同续签与履行合同
- 2025年度混凝土班组劳务施工质量监督合同
- 二零二五年度生物制药研发中心劳务合同
- 2025年度生态环保泥工包工不包料工程承包合同
- 二零二五年度版员工国际交流聘用合同
- 2025年度职业经理人职业规划与晋升合同
- 二零二五年度营业执照转让及行业规范遵守合同
- 2024年联勤保障部队第九四〇医院社会招聘考试真题
- 第二章《有理数的运算》单元备课教学实录2024-2025学年人教版数学七年级上册
- DB31-T 596-2021 城市轨道交通合理通风技术管理要求
- 华为智慧园区解决方案介绍
- 2022年江西省公务员录用考试《申论》真题(县乡卷)及答案解析
- 人教版八年级英语上册期末专项复习-完形填空和阅读理解(含答案)
- 一例蛇串疮患者个案护理课件
- 低压电工理论考试题库低压电工考试题
- 国家电网培训课件
- 五年级上册口算练习400题及答案
- 骆驼祥子选择题100道及答案
评论
0/150
提交评论