- class A
- {
- public:
- void function(){printf("Hello World");}
- };
- class B
- {
- public:
- virtual void function(){printf("Hello World");}
- };
- int _tmain(int argc, _TCHAR* argv[])
- {
- A* p1 = NULL;
- p1->function();
- B* p2 = NULL;
- p2->function();
- };
情况A(不是虚函数):输出Hello World,程序运行正常;
情况B(有虚函数):程序直接crash;
原因是:不是虚函数的情况,this指针当成第一个参数传入函数(一般是通过ecx寄存器),主要里面没有使用这个this指针,函数运行是没有问题,如果用到了this指针,譬如访问了对象的成员变量,同样会crash。
而虚函数的情况,就不一样了,这种情况下,对象的第一个成员是虚函数表指针(指向虚函数表,虚表指针的位置可能不不同的编译器有差异,但原理一样)。调用虚函数的时候,首先是通过对象地址(this指针)获得第一个成员(虚表指针)的值,然后再通过虚表指针+偏移获得相应虚函数的位置,再调用虚函数,其实这是C++多态的原理,因此这个地方因为对象指针为NULL,因此去空地址取虚表指针,自然crash了。