15 第十五章 面向对象编程

15 第十五章 面向对象编程

ID:36174015

大小:157.93 KB

页数:6页

时间:2019-05-07

15 第十五章 面向对象编程_第1页
15 第十五章 面向对象编程_第2页
15 第十五章 面向对象编程_第3页
15 第十五章 面向对象编程_第4页
15 第十五章 面向对象编程_第5页
资源描述:

《15 第十五章 面向对象编程》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、***********************************2010年07月30日***********************************第十五章面向对象编程1:面向对象编程基于三个基本概念:数据抽象、继承和动态绑定2:面向对象编程的关键思想是:多态性。C++中,多态性仅用于通过继承而相关联的类型的引用或指针。3:C++中,基类必须指出希望派生类重定义哪些函数,定义为virtual的函数是基类期待派生类重新定义的,基类希望派生类继承的函数不能定义为虚函数。4:C++中,通过基类的引用(或指针)调用虚函数时,发

2、生动态绑定。引用(或指针)既可以指向基类对象也可以指向派生类对象,这一事实是动态绑定的关键。5:继承层次的根类一般都要定义虚析构函数。6:保留字virtual的目的是启用动态绑定。成员默认为非虚函数,对非虚函数的调用在编译时确定。除了构造函数之外,任意非static成员函数都可以是虚函数。保留字virtual只在类内部的成员声明中出现,不能用在类定义体外部出现的函数定义上。7:protected成员:不能被类的用户访问,可被该类的派生类访问,派生类只能通过派生类对象访问其基类的protected成员,派生类对其基类类型对象的prot

3、ected成员没有特殊访问权限。例:voidBulk_item::memfcn(constBulk_item&d,constItem_base&b){doubleret=price;//ok,usesthis->priceret=d.price;//ok,usespricefromaBulk_itemobjectret=b.price;//error:noaccesstopriceformanItem_base}8:尽管不是必须这样做,派生类一般会重定义所继承的虚函数。如果派生类没有重定义某个虚函数,则使用基类中定义的版本。派生类必

4、须对想要重定义的每个继承成员进行声明。派生类中虚函数的声明必须与基类中的定义方式完全匹配,但有一个例外:返回对基类型引用(或指针)的虚函数,派生类中的虚函数可以返回基类函数所返回类型的派生类的引用(或指针)9:一旦函数在基类中声明为虚函数,它就一直是虚函数,派生类无法改变该函数为派生类这一事实。派生类重定义虚函数时,可以使用virtual保留字,但不是必须这样做。10:已定义的类才可以作为基类。最底层的派生类对象包含其每个直接基类和间接基类的子对象如果需要声明(但并不实现)一个派生类,则声明包含类名但不包含派生列表。//error:

5、aforwarddeclarationmustnotincludethederivationlistclassBulk_item:publicItem_base;//forwarddeclarationsofbothderivedandnonderivedclassclassBulk_item;classItem_base;11:C++中的函数调用默认不使用动态绑定。要触发动态绑定,要满足两个条件:(1)只有指定为虚函数的成员函数才能进行动态绑定(2)必须通过基类类型的引用或指针进行函数调用。12:基类类型引用和指针的关键点在于静态

6、类型(statictype,在编译时可知的引用类型或指针类型)和动态类型(dynamictype,指针或者引用所绑定的对象的类型,这是仅在运行时可知的)可能不同。13:引用和指针的静态类型和动态类型可以不同,这是C++用以支持多态性的基石。14:在某些情况下,希望覆盖虚函数机制并强制函数调用使用虚函数的特定版本,这时可以使用作用域操作符。为什么会希望覆盖虚函数机制?最常见的理由是:为了派生类虚函数调用基类中的版本。在这种情况下,基类版本可以完成继承层次中所有类型的公共任务,而每个派生类型值添加自己的特殊工作。派生类虚函数调用基类版本

7、时,必须显示使用作用域操作符。如果派生类函数忽略了这样做,则函数调用会在运行时确定并且将是一个自身调用,从而导致无穷递归。15:虚函数与默认实参:虚函数也可以有默认实参。通常,如果有用在给定调用中的默认实参值,该值将在编译时确定。如果一个调用省略了具有默认值的实参,则所有的值由调用该函数的类型定义,与对象的动态类型无关。通过基类的引用或指针调用虚函数时,默认实参为在基类虚函数声明中指定的值,如果通过派生类的指针或引用调用虚函数,则默认实参是在派生类的版本中声明的值。在同一虚函数的基类版本和派生类版本中使用不同的默认实参几乎一定会引起

8、麻烦。如果通过基类的引用或者指针调用虚函数,但实际执行的是派生类中定义的版本,这时就可能会出现问题。16:每一个类控制它所定义的成员的访问。派生类可以进一步限制但不能放松对所继承的成员的访问。17:若基类成员是public或prote

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。