C++知识点总结(15页).doc
《C++知识点总结(15页).doc》由会员分享,可在线阅读,更多相关《C++知识点总结(15页).doc(15页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、-C+知识点总结-第 15 页类和对象初步1. 类的定义 在定义外成员函数的实现2. 类的成员函数之间可以相互调用,类的成员函数也可以重载,也可设默认参数值3. 一般来讲,一个对象占用的内存空间的大小等于其成员变量的体积之和。每个对象都有自己的存储空间(成员变量),但成员函数只有一份 对象名.成员名 指针-成员名 引用名.成员名4. private:一个类的私有成员,只能在该类的成员函数中才能访问 public: proteced: 5. class 默认 private struct默认public6. 内联成员函数:成员函数名前加inline 或函数体写在类定义内部的成员函数。执行更快,但
2、会带来额外的内存开销构造函数1. 构造函数全局变量在堆上,系统自动初始化为零。局部变量在栈上,初始值是随机的,需要初始化。2. 构造函数:对对象进行初始化。构造函数执行时对象的内存空间已经分配,构造函数的作用是初始化这片空间。可重载,不写的话有默认构造函数,但是如果编写了构造函数,那默认构造函数不会再执行。是一类特殊的成员函数。不写返回值类型,函数名为类名。3. 对象在生成时一定会调用某个构造函数,一旦生成,不再执行构造函数。4. P183 Ctest *pArray3=new Ctest(4),new Ctest(1,2)5. 复制构造函数:其是构造函数的一种,只有一个参数,为本类的引用,防
3、止混淆,构造函数不能以本类的对象作为唯一的参数。 默认复制构造函数。6. 复制构造函数被调用的三种情形:1用一个对象去初始化另一个对象时Complex C1(C2) Complex C2=C1; 2 函数的参数是类A的对象。形参未必等于实参 函数中用对象的引用不会调用复制构造函数 void Function(const Complex &c)3 函数的返回值是类A的对象7. 类型转换构造函数:除复制构造函数外,只有一个参数的构造函数 C=68. 析构函数:在对象消亡时调用,可以定义其做善后工作。是一类特殊的成员函数,一个类有且只有一个构造函数。默认析构函数9. 注意:函数的参数对象以及作为函数
4、返回值的对象,在消亡时也会调用析构函数10. 构造函数 析构函数 变量的生存期: 全局变量在main函数开始执行前初始化。函数调用结束后静态局部对象不消亡。main函数结束时,静态局部对象先消亡,全局对象再消亡11. 静态成员变量和静态成员函数:实质是全局变量和全局函数,被所有的同类共享。生成在对象生成之前。计算体积时不会将静态成员变量算入其中 老师的coeblocks C0 13 静态成员变量必须在类定义外进行声明,声明的同时也可初始化。因为静态成员函数内部不作用于某个对象,所以不能访问非静态成员12. 常量对象和常量成员函数:常量对象一旦初始化后,值再也不能改变。常量对象和普通对象都可调用
5、常量成员函数。通过常量对象调用常量成员函数。常量成员函数内不能调用同类的非常量成员函数,静态成员函数除外。13. 封闭类:包含成员对象的类。在定义封闭类的构造函数时,用初始化列表的方式初始化。封闭类对象生成时,先执行所有成员对象友元和this1. 友元函数:把全局函数和其它类的成员函数声明为友元函数后,可直接在友元函数内部访问该类的私有成员;但不能把其它类的私有成员函数声明为友元。2. 全局函数声明为友元:friend 返回值类型 函数名(参数表); 3. 其它类的成员函数声明为友元:friend 返回值类型 其它类的类名:成员函数名(参数表);4. 友元类:类A将类B声明为自己的友元,则类B
6、中所有的成员函数都可访问类A对象中的私有成员。私有成员函数也可访问。5. 注意:友元关系不能传递。6. this指针:非静态成员函数的实际形参比编写的多一个,就是this指针,指向成员函数作用的对象。通过this指针找到对象所在的地址,继而找到对象非静态成员变量的地址。7. 注意:因为静态成员函数不作用于某个对象,所以在其内部无this指针,不能使用。运算符重载1. 运算符重载:是对已有的运算符赋予多重含义,使不同的运算符作用于不同的类型的数据时导致的不同的行为。 实质是编写运算符作为名称的函数。2. 返回值类型 operator 运算符(形参表).3. 使用了被重载的运算的表达式,会被编译成
7、对运算符函数的调用,实参是运算符的操作数,运算的结果是函数的返回值。运算符可多次被重载,可重载为全局函数和成员函数。重载为全局函数时,参数个数等于操作符的个数;重载为成员函数时,参数的个数等于操作数的个数减1. ab被重载为a.operator-(b);4. 类名(构造函数参数表)这个写法表示生成一个临时对象。该临时对象没有名字,生存期到包含它的语句执行完为止。5. C+规定 = 只能重载为成员函数.赋值运算符可以连用。6. const char *c_str() const return str); 两种错误的情形: char *p=s.c_str(); strcpy(s.c_str(),t
8、ianggong 1);7. a=b=hello;等价于a.operator=(b.operator=(hello);8. (a=b)=c;等价于(a.operator=(b).operator=(c);9. 深复制和浅复制:两个对象的指针成员变量指向同一个地方,指向两个不同的地方。10. 将运算符重载为友元函数11. 重载插入运算符和流提取运算符:cout是ostream类的对象。ostream类和cout都是在iostream头文件中声明的。ostream类将多次重载为成员函数。比如:ostream & ostream:operator( const char*s) . return *t
9、his;) ostream & ostream:operator(int n) . return *this;) 12. 返回值*this是cout的引用 coutstar war5;等价于(cout.operator(star war).operatorCStudent:PrintInfo();4. 复合关系和继承关系:复合关系,有,表现为封闭类,但不一定只是封闭类。即一个类以另一个类的对象作为成员变量。 继承关系 ,是,类B继承类A,满足B所代表的事物也是A所代表的事物5. 类A知道类B:类A的成员变量是类B的指针6. /导出类构造函数和析构函数的构建基类的构造函数和析构函数不能被派生类继
10、承。如果基类没有定义构造函数,派生类也可以不定义构造函数,全都采用缺省的构造函数,此时,派生类新增成员的初始化工作可用其他公有函数来完成。如果基类定义了带有形参表的构造函数,派生类就必须定义构造函数,提供一个将参数传递给基类构造函数的途径,以便保证在基类进行初始化时能获得必需的数据。如果派生类的基类也是派生类,则每个派生类只需负责其直接基类的构造,不负责自己的间接基类的构造。派生类是否要定义析构函数与所属的基类无关,如果派生类对象在撤销时需要做清理善后工作,就需要定义新的析构函数。多态与虚函数1. 多态:派生类对象的地址可以赋值给基类指针。对于通过基类指针调用基类和派生类中都有的同名的,同参数
11、的虚函数的语句,编译时不需要确定执行的是基类的还是派生类的虚函数。当程序运行到该语句时,如果基类指针指向的是一个基类对象,则调用基类的虚函数;如果基类指向的是一个派生类对象,则调用派生类的虚函数。这种机制成为多态;2. 面向对象程序设计语言有封装,继承,多态三种机制,这三种机制能够有效提高程序的可读性,可扩充性和可重用性。3. 多态指同一事物可以完成不同的功能。分为编译时的多态和运行时的多态。前者主要指函数的重载(包括运算符重载),对重载函数的调用。后者主要与继承,虚函数等概念有关。4. 虚函数:声明前面加了virtual关键字的成员函数。virtual 关键字只能在类定义中的成员函数声明处使
12、用,不能在类外编写成员函数体时使用。静态成员函数不能是虚函数。包含虚函数的类成为多态类。5. 多态可以简单地理解成同一条函数调用语句能调用不同的函数。或者对不同的对象发同一消息,使得不同对象有各自不同的行为。6. 注意:多态的语句调用的是哪个类的成员函数,是在运行时才能确定的,编译时不能确定。因此多态的函数调用语句是动态联编的,普通的函数调用语句时静态联编的。7. 通过基类引用实现多态。通过基类的引用调用虚函数的语句是多态的,即通过基类的引用调用基类和派生类中的同名同参表的虚函数时引用的是哪个类的对象,调用该对象的虚函数。8. 多态的实现原理:每一个有虚函数的类,都有一个虚函数表,列出了该类所
13、有虚函数的地址。该类的任何对象都存放着该虚函数表的指针。位于对象存储空间的最前端,在数据成员之前,里面存放着虚函数表的地址。9. 多态的实现过程:根据基类指针所指向的或基类引用所引用的对象中存放的虚函数表的地址,查找要调用的虚函数的地址,调用虚函数。10. 类的成员函数可以相互调用,在成员函数(静态,构造,析构除外)中调用同类的虚函数的语句是多态的。11. 在构造函数和析构函数中调用虚函数不是多态的,即编译时即可确定。如果本类有该函数,则调用本类的,本类没有调用直接基类的,基类没有,调用间接基类的。12. 注意:只要在基类中某个函数被声明为虚函数,则在直接和间接派生类中,同名同参数的成员函数即
14、使不写virtual也自动成为虚函数。13. 虚析构函数:如果一个基类指针指向new出来派生类的对象,释放该对象时是通过该基类指针来完成的。14. 如果基类的析构函数是虚函数,派生类的析构函数即使不用virtual关键字也自动成为虚函数。15. 注意:!析构函数可以是虚函数,但构造函数不可以!16. 纯虚函数:没有函数体的虚函数;在函数声明后加=0;17. 抽象类:包含纯虚函数的类;不能生成独立的对象,但抽象类可以作为基类,派生出新类。因此,独立的抽象类的对象不存在,但是被包含在派生类对象中的抽象类的对象,是可以存在的(但要实例化,有函数体)。18. 可以定义抽象类的指针或引用,让他们指向或引
15、用抽象类的派生类的对象,实现多态。19. 如果一个类从抽象类派生而来,那么当且仅当它对基类中所有纯虚函数都进行覆盖并都写出函数体(也是),它才能成为非抽象类。函数调用也会带来降低效率的问题,因为调用函数实际上将程序执行顺序转移到函数所存放在内存中某个地址,将函数的程序内容执行完后,再返回到转去执行该函数前的地方。这种转移操作要求在转去前要保护现场并记忆执行的地址,转回后先要恢复现场,并按原来保存地址继续执行。 因此,函数调用要有一定的时间和空间方面的开销,于是将影响其效率。特别是对于一些函数体代码不是很大,但又频繁地被调用的函数来讲,解决其效率问题更为重要。引入内联函数实际上就是为了解决这一问
16、题。 优点:可以加快代码的执行速度,当程序中调用内联函数时,该函数直接嵌入到每个调用语句处,每次函数调用时都用相对应的一段代码代替。可见它是以目标代码的增加为代价来换取时间的节省 主要解决功能相对简单、规模不大但使用相当频繁的程序运行效率问题。 使用内联函数时,遵守以下规则: 1. 内联函数体内不能包含任何静态变量,不能使用循环语句、switch;不能递归。 2.内联函数的定义必须出现在第一次被调用之前。 3.如果函数返回类型为void,则不能有return 语句。二:指针 通过指针引用数组元素 int a10; int *p; p+是合法的,而a+是错误的。a是数组名,它是数组的首地址,是常
17、量;指向函数的指针变量:存放函数入口地址,指向的是程序代码存储区。 1、函数调用可以通过函数名调用,也可以通过指向函数的指针变量调用。 2、(*p) ( )表示定义一个指向函数的指针变量,在程序中把哪个函数的地址赋给它,它就指向哪一个函数。 3、给函数指针变量赋值时,只需给出函数名而不必给出参数。 p = max 4、用函数指针变量调用函数时,只需将(*p)代替函数名,在(*p)之后的括弧中根据需要写实参。 c=(*p)(a,b) 5、对指向函数的指针变量不能运算const pointer一个指针涉及到两个变量,一个是指针本身,另一个是指向的变量1.指向常量的指针const放在指针类型前,在程
18、序中不能通过指针来间接修改指针所指向的内存空间的值,但可以改变指向的空间int a = 10;const int b = 20;const int* pa = &a;const int* pb = &b;a = 100; / okb = 200; / error*pa = 100; / error*pb = 200; / errorpb = &a; / okpa = &b; / ok2.指针常量const放在”*”和指针名之间,不能改地址能改所指向的值。int b =28;int* const pb = &b;*pb = 100; / okpb+; / error在定义指针常量时,必须将其初始
19、化。3.指向常量的指针常量const在上述两个地方都加。既不允许修改指针值,也不允许修改指针变量所指向的值const int a = 10;const int * const pa = &a;a = 100; / error*pa = 100; / errorpa +; / error三:引用标题引用与指针的区别引用是 C+ 语言引进的概念,在 C 语言中没有。1)、指针是变量,引用是别名 引用是别名,引用本身没有地址。 2)、指针可作数组元素、引用不可 例: int *pa5;/指针数组 int a5; int &rea5=a;/不可 3)、可以有空指针,不可有空引用 例: int *p=n
20、ull;/合法 int &re=null;/无意义四:类(class)私有(private)的数据和函数,只允许本类的成员函数访问或调用;保护(protected:)的数据和函数,允许本类和本类派生类的成员函数访问或调用;公有(public:)的数据和函数,允许本类和其它类的函数访问或调用。静态数据成员: 1.类的静态数据成员为该类的所有对象所共享。 2. 必须在类外文件作用域中的某个地方对静态数据成员赋初值(因为构造函数多次被调用,而静态数据成员只初始化1次): : = Const 成员函数中确保不会修改任何本类对象的数据成员。class constfunprivate:int a;publ
21、ic:void nonconstFunc( )a=18; /okvoid Func( ) consta=18 /errorthis指针:this指针是指向对象的指针,隐含在类的成员函数中,用来指向成员函数所属类的正在被操作对象。this指针可以看作是类自身的一个引用。构造函数的调用顺序 对于构造函数,先执行基类的,再执行对象成员的,最后执行派生类的。 对于析构函数,先执行派生类的,再执行对象成员的,最后执行基类的。导出类构造函数和析构函数的构建基类的构造函数和析构函数不能被派生类继承。如果基类没有定义构造函数,派生类也可以不定义构造函数,全都采用缺省的构造函数,此时,派生类新增成员的初始化工作
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- C+ 知识点 总结 15
限制150内