内联函数是指在调用函数的地方插入函数实现代码,节省函数调用的开销。
这是一种用空间换时间的做法。
声明内联函数时用inline关键字。 在类体内定义的函数默认为内联函数(构造函数也可以为内联函数)
要注意,无法获得内联函数的地址。
内联函数,构造函数,静态成员函数不能为virtual函数
1> 内联函数
内联函数是在编译时期展开,而虚函数的特性是运行时才动态联编,所以两者矛盾,不能定义内联函数为虚函数。
用内联取代宏:(内联与宏的区别)
1.内联函数在运行时可调试,而宏定义不可以; 2.编译器会对内联函数的参数类型做安全检查或自动类型转换(同普通函数),而宏定义则不会; 3.内联函数可以访问类的成员变量,宏定义则不能; 4.在类中声明同时定义的成员函数,自动转化为内联函数。
2> 构造函数
构造函数用来创建一个新的对象,而虚函数的运行是建立在对象的基础上,在构造函数执行时,对象尚未形成,所以不能将构造函数定义为虚函数。
3> 静态成员函数
静态成员函数属于一个类而非某一对象,没有this指针,它无法进行对象的判别。
这个可以从两个角度去理解: 1。virtual意味着在执行时期进行绑定,所以在编译时刻需确定信息的不能为virtual 构造函数需在编译时刻,因为需构造出个对象,才能执行动作。 静态成员函数不属于任何一个对象,编译时刻确定不存在执行的时候选择执行哪个的情形。 内联函数,由于属于编译器的建议机制,所以其实可以virtual。 2。virtual意味着派生类可以改写其动作 派生类的构造函数会先执行基类的构造函数而不是取代基类构造函数,也就是说基类的构造函数可以看作派生类构造函数的组成,所以并不能改写这个函数。 静态成员函数不属于任何一个对象,所以更不能改写其动作了。
虚析构函数(virtual destructor)
当你可能通过基类指针删除派生类对象时,建议使用虚析构函数。虚函数绑定到对象的类的代码,而不是指针/引用的类。如果基类有虚析构函数,delete basePtr(基类指针)时,*basePtr 的对象类型的析构函数被调用,而不是该指针的类型的析构函数。简单讲,这个类有虚函数就应该有虚析构函数。一旦你在类中加上了一个虚函数,你就已经需要为每一个对象支付空间代价(每个对象一个指针),所以这时使析构函数成为虚拟的通常不会额外付出什么。对于那些trivial且没有子类的类,虚析构函数只会增加开销,不要使用。