版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
PolymorphismandVirtualFunctionsC++面向对象程序设计双语教程(第3版)Chapter701PolymorphismThekeyideabehindOOPispolymorphism.PolymorphismisderivedfromaGreekwordmeaning“manyforms”.Wespeakthetypesrelatedbyinheritanceaspolymorphictypes,becauseinmanycaseswecanusethe"manyforms³ofaderivedorbasetypeinterchangeably.IntroductiontoPolymorphismPolymorphismInprogramminglanguages,polymorphismmeans
that
some
codesoroperationsor
objectsbehavedifferentlyindifferentcontexts.Forexample,the+operatorinC++implementtheadditionoperationwithdifferentdataordifferenttypes.IntroductiontoPolymorphismPolymorphismPolymorphismisakeyfeatureofobject-orientedprogrammingthatallowsthevaluesofdifferentdata
typestobehandledbyusingauniforminterface.多态性是一个面向对象程序设计的关键特性,它允许使用统一的接口处理不同数据类型。PolymorphismThepurposeofpolymorphismistoimplementastyleofprogrammingcalledmessage-passingintheliterature,inwhichtheobjectsofvarioustypesdefineacommoninterfaceofoperationsforusers.PolymorphismTypically,polymorphismoccurswhenthereisaclasshierarchyinwhichtheclassesarerelatedbyinheritance.PolymorphismBindingWhenaC++programisexecuted,itexecutessequentially,beginningatthetopof
functionmain.Whenafunctionealliseneountered,thepointofexecutionjumpstotheinitial
pointofthefunctionbeingcalled.HowdoestheCPUknowtodothis?PolymorphismWhenaprogramiscompiled,thecompilerconvertseachstatementinyourC++programintooneormorelinesofmachinelanguage.Eachlineofmachinelanguageisgivenitsownuniquesequentialaddress.Thisisnodifferentforfunctionswhenafunctionisencountered,itisconvertedintomachinelanguageandgiventhenextavailableaddress.Thus,eachfunction
endsupwithauniquemachinelanguageaddress.PolymorphismBindingisaprocessthatisusedtoconvertidentifiers
intomachinelanguageaddresses.Inotherwords,bindingisanassociation,suchasbetweenidentifiers
andoperations.Therearetwotypesofbindingaccordingtothetimeatwhichabindingtakesplace,i.e.staticbindingand
dynamicbinding.绑定是一种用于将标识符(如变量和函数名)转换成机器语言地址的过程。换句话说,绑定是一种关联,例如在标识符(变量或函数名)和操作(类型或特定函数体)之间的关联。根据绑定发生的时间,有两种类型的绑定,即静态绑定和动态绑定。PolymorphismStaticBindingBydefault,Ct+matchesafunctioncallwiththecorrectfunctiondefinitionatcompiletime.Thisiscalledstatiebinding.Thiskindofbindingisalsoknownaseompile-timebinding.Forexample,theoperatoroverloadingandthefunctionoverloadingmentionedinthepreviouschaptersarethatthecompilerassociatestheoperatorfunctionsandoverloadedfunctionswiththeirdefinitionsatcompile-time.PolymorphismEachfunctionhasauniqueaddress.Thus,whenthecompilerencountersafunctioncall,itreplacesthefunctioncallwithamachinelanguageinstructionthattellstheCPUtojumptotheaddressofthefunction.PolymorphismWhenthecompilermatchesafunctioncallwiththecorreetfunctiondefinitionatrun-time,thisiscalleddynamiebinding.Thecodeassociatedwiththeproceduredoesnotknowuntiltheprogramisexecuted.Thiskindofbindingisalsoknownasrun-timebinding.Youcandeclare
afunctionwiththevirtualkeywordifyouwantthecompilertousedynamicbindingforthatspecificfunction.DynamicBindingPolymorphism02VirtualFunctionsAvirtualfunctionisamemberfunctionofthebaseclassandisredefinedbythederivedclass.Thecompilerwillguaranteethecorrectcorrespondencebetweenobjectsandthefunctionsappliedtothem.Avirtualfunctioniscreatedusingthekeywordvirtualwhichprecedesthenameofthefunction.VirtualFunctionsForexample,supposeagraphicsprogramincludesseveraldifferentshapes:acubeandacuboid,andsoon,asshowninFigure7-1.VirtualFunctionsToenablethiskindofbehavior,wedeclarefunctionvolumeinthebaseclassasavirtualfunction,andweoverridefunctionvolumeineachofthederivedclassestocalculatethevolumeofappropriateshape.VirtualFunctionsWhenaderivedclassinheritstheclasscontainingthevirtualfunction,ithastheabilityto
redefinethevirtualfunctions.Avirtualfunctionhasdifferentfunctionalityinthederivedclass.Thevirtualfunetionimplementsthephilosophyofoneinterfaceandmultiplemethods.VirtualFunctionsVirtualfunetionscanbeaccessedbyusingabaseclasspointer.Apointertothebaseclasscanbecreated.Abaseclasspointercancontaintheaddressofthederivedobjectasthederivedobjectcontainsthesubsetofabaseclassobject.VirtualFunctionsEveryderivedclassisalsoabaseclass.Whenabaseclasspointercontainstheaddressofthederivedclassobject,atruntime,whichversion
ofthevirtualfunctionbeingcalleddependsonthetypeofobjectcontainedbythepointer.
Hereisaprogramwhichillustratestheworkingofvirtualfunctions.VirtualFunctionsOnceafunctionisdeclaredasvirtual,itremainsvirtualallthewaydowntheinheritancehierarchy
fromthatpoint,evenifthatthefunctionisnotexplicitlydeclaredasvirtualwhenaclassoverrides
it.Ifthememberfunctioninthederivedclassisvirtual,thekeywordvirtualcanbeomittedinthe
derivedclass.Butthekeywordvirtualcannotbeomittedinthebaseclass.VirtualFunctionsExtensibilityIfthevolumefunetionisdefinedasvirtualinthebaseclass,youcanaddasmanynewclasstypesasyouwantwithoutchangingthefnfunction.Inawell-designedOOPprogram,mostorallyourfunetionswillfollowthemodeloffunctionfnandcommunicateonlywiththebase-classinterface.VirtualFunctionsExtensibilitySuchaprogramisextensiblebecauseyoucanaddnewfunctionalitybyinheritingnewdatatypesfromthecommonbaseclass.Thefunetionsthatmanipulatethebase
classinterfacewillnotneedtobechangedatalltoaccommodatethenewclasses.HereistheShapeexamplewithmorevirtualfunctionsandanumberofnewclasses,allofwhichworkcorrectlywiththeold,unchangedfnfunction.VirtualFunctionsTheextensibilityofclasshierarchymentionedinExample7-3isshowninFigure7-2.VirtualFunctionsHowcandynamiebindinghappenbyvirtualfunctions?Alltheworkgoesonbehindthescenesbythecompiler,whichinstallsthenecessarydynamicbindingmechanismwhenyouaskitto(youareaskedtocreatevirtualfunctions).PrincipleofVirtualFunctionsVirtualFunctionsBecauseprogrammersoftenbenefitfromunderstandingthemechanismofvirtualfunctionsinC++,thissectionwillelaborateonthe
waythecompilerimplementsthismechanism,Thevirtualkeywordtellsthecompilerthatitshouldnotperformstaticbinding.PrincipleofVirtualFunctionsVirtualFunctionsIneachclasswithvirtualfunctions,itsecretlyplacesapointer,calledthevpointer(abbreviatedasVPTR),whichpoints
totheVTABLEforthatobject,asshowninFigure7-3.VirtualFunctionsVirtualDestructorsOnethingrecommendedfortheclasswithpointermembervariablesisthattheclassshouldhavethedestructor(seeSection4.6.2).Thedestructorisautomaticallyexecutedwhentheclassobjectgoesoutofthescope.Then,iftheobjectcreatesdynamicobjects,thedestructorcanbedesignedtodeallocatethestorageforthem.VirtualFunctionsThebaseclassdestructorshouldalwaysbevirtual.Supposeyouusethedeleteoperatorwithabaseclasspointertoaderivedclassobjecttodestroythederivedclassobject.Ifthebaseclassdestructorisnotvirtual,butlikeanormalmemberfunction,thenthedeleteoperator
callsthedestruetorforthebaseclass,butnotthedestructorforthederivedclass.VirtualFunctionsIfnoneofthedestructorshasanythingimportanttodo(likedeallocatingmemoryobtainedwith
delete),thenvirtualdestructorsaren'tnecessary.But,ingeneral,toensurethatderivedclassobjects
aredestroyedproperly,youshouldmakevirtualthedestruetorsinallbaseclasses.VirtualFunctionsWehaveintroducedfunctionoverloadingandfunctionoverridingintheprevioussections.Thesetermsaresimilar,andtheydosimilarthings.Whenyouoverrideamemberfunetionoftheclass,youcreateamemberfunetioninaderivedclasswiththesamenameasafunetioninthebaseclassandthesamesignature.FunctionOverloadingandFunctionOverridingVirtualFunctionsIfwedefineafunctionasvirtualinthebaseclass,thefunctionwiththesame
name
andsamesignaturebutnokeywordvirtualinthederivedclassisalsothevirtualfunctionbecauseofoverriding.VirtualFunctions03AbstractBaseClassesOfteninadesign,youwantthebaseclasstopresentonlyaninterfaceforitsderivedclasses.Thatis,youdon'tallowanyonetocreateanobjectofthebaseclass,butonlywanttoupcasttoitsothatitsinterfacecanbeused.Thisisaccomplishedbymakingthatclassabstraet.AbstractBaseClassesAbstractbaseclassesactastheexpressionsofgeneralconceptsfromwhichmorespecific
classescanbederived.Ifanabstractbaseclasscannotbeinstantiated,itexistsextensivelyforinheritanceandit
mustbeinherited.AbstractBaseClassesTherearescenariosinwhichitisusefultodefineaclassthatisnotintendedtobeinstantiatedbecausesuchclassesnormallyareusedasbase-classesininheritance
hierarchies.AbstractBaseClassesThisclassmustbeinherited.Thisclassismostlyusedasabaseclass.Youcannotcreatean
objectofanabstractelasstype;however,youcanusepointersandreferencestoabstractclasstypes.AbstractBaseClassesAclassthatcontainsatleastonepurevirtualfunctionisconsideredasanabstractclass.Theclassesderivedfromtheabstractclassmustimplementthepurevirtualfunctionorthey,too,areabstractclasses.AbstractBaseClassesApurevirtualfunctionisafunctionwhichcontainsnodefinitioninthebaseclass.Youdeclareapurevirtualfunctionbyusingapurespecifier(=0)inthedeclarationofavirtualmemberfunctionintheclassdeclaration.纯虚函数是一个在基类中没有定义的函数。在类声明时使用pure说明符(=0)将一个虚成员函数声明为纯虚函数。AbstractBaseClassesAclasswhichcontainsoneormorepurevirtualfunctioniscalledanabstractbaseclass.Abstractbase
classcsactasexpressionsofgeneralconceptsfromwhichmorespecificclassescanbederived.包含一个或多个纯虚函数的类称为抽象基类。抽象基类作为通用概念的表示,从中可以导出更多具体的类。AbstractBaseClassesThestatementinLine6tellsthecompilertoreserveaslotforafunetionintheVTABLE,butnottoputanaddressinthatparticularslot.Evenifonlyonefunctioninaclassisdeclaredaspurevirtual,theVTABLEisincomplete.AbstractBaseClassesIftheVTABLEforaclassisincomplete,whatisthecompilersupposedtodowhen
someonetriestomakeanobjectofthatclass?Itcannotsafelycreateanobjectofanabstractclass,soyougetanerrormessagefromthecompiler.Thus,thecompilerguaranteesthepurityoftheabstractclass.Bymakingaclassabstract,youcanensurethattheclientprogrammercannotmisuseit.AbstractBaseClassesPurevirtualfunctionsarehelpfulbecausetheymakeexplicittheabstractnessofaclass
andtellboththeuserandthecompilerhowitwasintendedtobeused.AbstractBaseClasses04CaseStudy:AMini-SystemWedesignamini-systemthatineludesdifferenttypesofpeopleintheuniversity.Therearefiveclasses,thatis,Person,Student,Employee,FacultyandStaff,tobedefined.AclassnamedPersonhastwoderivedclassesnamedStudentandEmployee.MakethederivedclassesFaculty
andStaffofEmployee.CaseStudy:AMini-SystemApersonhasaname,address,phonenumberande-mailaddress.A
studenthasaclassstatus(freshmen,sophomore,junior,orsenior).Anemployeehasanoffice,salary,anddate-hired.DefineaclassnamedDatethatcontainsthefieldsyear,monthandday.CaseStudy:AMini-SystemAfacultymemberhasofficehoursandarank.Astaffmemberhasatitle.Defineaconstantvirtualto
StringfunctioninthePersonclassandoverrideitineachclasstodisplaytheclassnameand
theperson'sname.CaseStudy:AMini-SystemTheUMLdiagramofthesesixclassesisdescribedinFigure7-4.CaseStudy:AMini-System谢谢观看C++面向对象程序设计双语教程(第3版)TemplatesC++面向对象程序设计双语教程(第3版)Chapter801Introduction
to
TemplatesManyC++programsusecommondatastructureslikestacks,queuesandlists.Aprogrammayrequireaqueueofcustomersandaqueueofmessages.Onecouldeasilyimplementaqueueofcustomers,thentaketheexistingcodeandimplementaqueueofmessages.IntroductiontoTemplatesTheprogramgrows,andnowthereisaneedforaqueueoforders.Sojusttakethequeueofmessagesandconvertthattoaqueueoforders(copy,paste,find,andreplace).Needtomakesomechangestothequeueimplementation?IntroductiontoTemplatesNotaveryeasytask,sincethecodehasbeenduplicatedinmanyplaces.Reinventingsourcecodesisnotanintelligentapproachinanobject-orientedenvironmentwhichencouragesreusability.IntroductiontoTemplatesItseemstomakemoresensetoimplementaqueuethatcancontainanyarbitrarytyperatherthanduplicatingcode.Howdoesonedothat?Theansweristousetypeparameterization,ormorecommonlyreferredtoastemplates.IntroductiontoTemplatesToavoidrewritingcodethatwouldbeidenticalexceptfordifferenttypes.Sometimesyoudonotsimplyrelyonimplicittypeconversionorpromotionmatch,andyoucannotstuffeverythingintoaclasshierarchy.IntroductiontoTemplatesGenericprogrammingisastyleofprogramminginwhichalgorithmsarewrittenintermsoftypes
to-be-specified-later.Thenthesetypesworkingasparametersareinstantiatedwhenspecifictypesareneeded.Templatesprovidedirectsupportforgenericprogramming,thatis,programmingusingtypesasparameters.TheC++templatemechanismallowsatypetobeaparameterinthedefinitionofaclassorafunction.IntroductiontoTemplatesC++providestwokindsoftemplates:classtemplatesandfunctiontemplates.Usefunctiontemplatestowritegenericfunctionsthatcanbeusedwitharbitrarytypes.Forexample,onecanwritesearehingandsortingroutinesthatcanbeusedwithanyarbitrarytype.ThegenericalgorithmsintheStandardTemplateLibrary(i.e.STL)havebeenimplementedasfunctiontemplates,andthecontainershavebeenimplementedasclasstemplates.IntroductiontoTemplates02FunctionTemplatesLet'simaginethatwewanttowriteafunctiontocomparetwovaluesandindicatewhetherthefirstislessthan,equalto,orgreaterthanthesecondone.Inpractice,wewouldwanttodefineseveralsuchfunctions,eachofwhichcouldcomparevaluesofagiventype.DefinitionofFunctionTemplatesFunctionTemplatesThetwofunctionsarenearlyidentical.Theonlydifferencebetweenthemisthetypeoftheirparameters.Thefunetionbodyisthesameineachfunction.Havingtorepeatthebodyofthefunctionforeachtypethatwecompareistediousanderror-prone.FunctionTemplatesMoreimportantly,we
needtoknowinadvanceallthetypesthatwemighteverwanttocompare.Thisstrategy
cannotworkifwewanttobeabletousethefunctionontypesthatwedon'tknowabout.
Therefore,wethinkthatthesecomparefunctionsneedtobedefinedasagenericfunetion.FunctionTemplatesFunctionTemplateInstantiationWhenafunctiontemplateisfirstcalledforeachtype,thecompilercreatesaninstantiation.Eachinstantiationisaversionofthetemplatedfunctionspecializedforthetype.Thisinstantiationwillbeealledeverytimethefunctionisusedforthetype.FunctionTemplatesWhenthecompilerencountersthiscalltoatemplateinstantiation,itusesthetemplatetoautomaticallygenerateafunctionreplacingeachappearanceofTbythetypepassedastheactualtemplateparameter(intinthiscase)andthencallsit.Thisprocessisautomaticallyperformedbythecompilerandisinvisibletotheprogrammer.FunctionTemplatesFunctionTemplatewithDifferentParameterTypesSincethefunctiontemplateinExample8-1inchidesonlyonetemplateparameter(typenameT)andthefunctiontemplateitselfacceptstwoparameters,bothofthesameTtypes,wecannotcallourfunctiontemplatewithtwoobjectsofdifferenttypesasarguments.FunctionTemplatesFunctionTemplateOverloadingFunctiontemplatesandoverloadingareintimatelyrelated.Onecandeclareseveralfunctiontemplateswiththesamenameandevendeclareacombinationoffunctiontemplatesandordinaryfunctionswiththesamename.Whenanoverloadedfunctioniscalled,overloadingresolutionisnecessarytofindtherightfunctionortemplatefunction
toinvoke.FunctionTemplates03ClassTemplatesJustaswecandefinefunctiontemplates,wecanalsodefineclasstemplates.Forexample,a"stack³isadatastruetureintowhichweinsertitemsatthetopandretrievethoseitemsinlast-in,first-outorder.Itisindependentofthetypeoftheitemsbeingplacedinthestack.Normally,aStackclasscanbedefinedbyaspecifieddatatype.DefinitionofClassTemplatesClassTemplatesIfyouwanttocreatea
wonderfulopportunityforsoftwarereusability,youneedtodefineagenericStaekclassandtoinstantiatetheclassthatisthetype-specificversionsofthegenericStackclass.C++providesthiscapabilitythroughtheclasstemplate.ClassTemplatesAclasstemplateiscalledaparameterizedtype,becauseitrequiresoneormoretypeparameterstospecify
howtocustomizea"genericclass"templatetoformaclass-templatespecialization.类模板称为参数化类型,因为它们需要一个或多个类型参数来指定如何自定义“通用类”模板以形成类模板专用化。ClassTemplatesClassTemplateInstantiationItiseasytouseaclasstemplate.Createtherequiredclassesbypluggingintheactualtypeforthetypeparameters.Thisprocessiscommonlyknownas
"Instantiatingaelass".HereisasampledriverclassthatusesclasstemplateStack.ClassTemplatesTheprocessofgeneratingaclassdeclarationfromatemplateclassandatemplateargumentisoftencalledclasstemplateinstantiation.从模板类和模板参数生成类声明的过程通常称为类模板实例化。ClassTemplatesNow,letusconsidertheuserprogramthatexercisesclasstemplateStack.Althoughtemplatesoffersoftware-reusabilitybenefits,rememberthatmultipleclass-templatespecializationsareinstantiatedinaprogram(atcompiletime),eventhoughthetemplateiswrittenonlyonce.ClassTemplatesTheprogrambeginsbyinstantiatinganobjeetdoubleStaekofsize5inLine5.ThisobjectisdeclaredtobeofclassStack<double>(pronounced
"Stackofdouble").ThecompilerassociatestypedoublewithtypeparameterTintheclasstemplatetoproducethesourcecode
foraStackclassoftypedouble.ClassTemplatesClassStackprovidestheisFullfunction,whichtheprogrammercanusetodeterminewhetherthestackis
fullbeforeattemptingapushoperation.Thiswouldavoidthepotentialerrorofpushingontoa
fullstack.ClassTemplates04Non-TypeParametersforTemplatesBesidesthetemplateargumentsthatareprecededbythetypenamekeywords,which
representtypes,templatescanalsohaveregulartypedparameters,likethosefoundinfunctions.Asanexample,takealookatthisclasstemplatethatisusedtocontainsequencesofelements.Non-TypeParametersforTemplatesInthisexample,integerNisanon-typetemplateparameter.Whentheobjectsofthe
templatearecreatedinLines24and25,aninteger5isdirectlypassedintoN.Itisalsopossibletosetdefaultvaluesortypesforclasstemplateparameters.Non-TypeParametersforTemplates05AbstractBaseClassesClasstemplatescaninheritorbeinheritedfrom.Formanypurposes,thereisnothing
significantlydifferentbetweenthetemplateandnon-templatescenarios.DerivationandClassTemplatesHowever,thereisoneimportantsubtletywhenderivingaclasstemplatefromabaseclassreferr
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2026兴业银行莆田分行春季校园招聘备考题库带答案详解(考试直接用)
- 2026浙江金华市第五医院(浙江医院金华分院)编外人员招聘4人备考题库(第二批)及答案详解(基础+提升)
- 2026新疆克州柔性引进紧缺人才招募82人备考题库带答案详解
- 2026爱莎荔湾学校专任教师招聘备考题库(广东)含答案详解(典型题)
- 2026岚图区域市场岗位社会招聘备考题库及完整答案详解
- 2026广东珠海市金湾区红旗镇中心幼儿园代产假教师招聘2人备考题库带答案详解ab卷
- 2026浙江丽水市市直医疗卫生健康单位招聘卫技人员36人备考题库及完整答案详解1套
- 钢结构测量施工方案
- 2026广西物资学校招聘高层次人才4人备考题库带答案详解
- 2026北京市中医药研究所面向社会人员招聘1人备考题库(第二批)含答案详解(典型题)
- 2025广东省高中美术学业水平考试试题库及答案
- 网络创业培训课件
- 企业内部财务审计检查表范本
- 高标准农田建设及智能化管理系统开发
- 市政道路工程施工风险清单及管控措施
- 吉林省长春市重点名校2025年高三最后一模化学试题含解析
- 门窗制造企业管理制度汇编
- (完整版)小学1-6年级英语单词(人教版)
- 2024年北京大学强基计划数学试卷试题真题(含答案详解)
- 聚合物基复合材料的界面1
- 《文化与人文地理学》课件
评论
0/150
提交评论