有C++的高手么

习惯了写C,写C++的时候遇到一个奇怪的问题,想不明白。

	PizzaStore* ps = NULL;
	//ps = new PizzaStore(factory);
	ps->orderPizza("NYStyleCheesePizza");

不注释的话,程序正常运行。
问题是注释了第二行,程序也能正常运行。
它是如何通过一个NULL指针找到orderPizza并执行它的呢?

有没有高手可以解释一下是为什么呀?谢谢!

举个简单的例子,假如有如下的一段代码:

class MyClass
{
public:
int i;
void hello()
{
printf(”hello\n”);
}
void print()
{
printf(”%d\n”, i);
}
};

void main()
{
MyClass* pmy = NULL;
pmy->hello();
}

看上面的这段代码,似乎很诡异。 用一个空指针调用成员函数,简直是天大的错误,可以遗憾的是,却是可行的,至少对于上面的这段程序来说,不会照成错误。
为什么?
其实,这并不是十分神秘的问题,假如你曾经使用过C封装结构的话,对于这个问题,是十分好理解的。
在类初始化的时候,编译器会将它的函数分配到类的外部,当然这也包括静态成员函数,这样的做法,主要是为了节约内存,这也是为什么静态函数可以在对象初始化之前运行的原因。
大家知道,每个对象,都有一个指向自己的this指针,这个指针的值,将会因为对象的不同而不同,它的作用主要就是用来区分不同的对象,这样你就可以根据它来访问不同的对象的成员变量。然而,我们main函数中的hello函数并没有使用类中的任何成员变量,所以,它也就不会用到this指针,此时的this指针是NULL。从而我们就可以没有障碍的使用hello函数,
然而相对的是,如果你在pmy->hello()之后接着调用pmy->print(),那么将会报空指针错误,因为这个函数试图用this指针访问成员变量i。