有如下代码:
class Base
{
public:
};
class Derive :public Base
{
public:
};
class Derive2:public Base
{
public:
};
一、静态类型和动态类型 静态类型:对象定义时的类型,编译期间就确定好了。
void main()
{
Base base;
Derive derive;
Base *pbase;
Base *pbase2 = new Derive();
Base *pbase3 = new Derive2();
system("pause");
}
动态类型:对象目前所指向的类型(运行的时候才决定的类型),一般只有指针或者引用才有动态类型。而且一般都是父类的指针或者引用。
void main()
{
Base base;
Derive derive;
Base *pbase;
Base *pbase2 = new Derive();
Base *pbase3 = new Derive2();
system("pause");
}
另外,动态类型在执行过程中可以改变,比如。
pbase = pbase2;
pbase = pbase3;
二、静态绑定和动态绑定 静态绑定:绑定的是静态类型,所对应的函数或者属性依赖于对象的静态类型 ,发生在编译期间
动态绑定:绑定的是动态类型,所对应的函数或者属性依赖于对象的动态类型,发生在运行期间。
2.1 普通成员函数是静态绑定,而虚函数时动态绑定 2.2缺省参数一般是静态绑定
三、继承的非虚函数坑 看如下代码:
class Base
{
public:
void myfunc()
{
cout << "Base::mufunc()\n";
}
};
class Derive :public Base
{
public:
void myfunc()
{
cout << "Derive::mufunc()\n";
}
};
class Derive2:public Base
{
public:
};
void main()
{
Derive derive;
Derive *pderive = &derive;
pderive->myfunc();
Base *pbase = &derive;
pbase->myfunc();
system("pause");
}
结果:  结论:不应该在子类中重新定义一个继承来的非虚函数。 四、虚函数的动态绑定 看代码:
void main()
{
Derive derive;
Derive *pderive = &derive;
pderive->myfunc();
Base *pbase = &derive;
pbase->myfunc();
cout << "-----------------\n";
pderive->myvirfunc();
pbase->myvirfunc();
Base base;
pbase = &base;
pbase->myvirfunc();
system("pause");
}
结果:  虚函数是动态绑定;换句话说 myvirfunc()是虚函数,这里到底执行哪个myvirfunc()取决于调用者的动态类型。 五、重新定义虚函数的缺省参数坑
class Base
{
public:
void myfunc()
{
cout << "Base::mufunc()\n";
}
virtual void myvirfunc(int nvalue = 1)
{
cout << "Base::myvirfunc(),nvalue:" << nvalue << endl;
}
};
class Derive :public Base
{
public:
void myfunc()
{
cout << "Derive::mufunc()\n";
}
virtual void myvirfunc(int nvalue = 2)
{
cout << "Derive::myvirfunc(),nvalue:" << nvalue << endl;
}
};
class Derive2:public Base
{
public:
};
void main()
{
Derive derive;
Derive *pderive = &derive;
pderive->myfunc();
Base *pbase = &derive;
pbase->myfunc();
cout << "-----------------\n";
pderive->myvirfunc();
pbase->myvirfunc();
Base base;
pbase = &base;
pbase->myvirfunc();
system("pause");
}
结果:  调用的是子类的myvirfuc(int nvalue = 2),但参数却是父类的nvalue=1. 总结:缺省参数一般是静态绑定。不要重新定义父类虚函数的缺省参数值。
六、c++中的多态性的体现

class A
{
public:
virtual void myvirfunc()
{
}
};
void main()
{
A *pa = new A();
pa->myvirfunc();
A a;
a.myvirfunc();
system("pause");
}
 
|