class的构造函数,是在生成对象实例时系统自动调用的,一般来讲开发着一般不能直接调用构造函数。
但是在某些特殊用法下开发人员需要调用构造函数来完成,对象实例的生成。
例如:在memory pool编程中,预先申请一块大的普通内存,在使用过程中需要将其中的一小块转换为一个对象实例,
在这种场景下就需要显式调用构造函数。
定义class AA:
char * ptr = (char *)malloc(sizeof(AA));
在需要的时候我们需要将ptr转换成AA的对象实例,如果采用如下方式调用:
AA * aa = (AA *)ptr;
那么class AA的构造函数不会被唤起,则这块内存还不是AA的对象实例。
此时如果作如下操作:aa->GetI();
VC6.0环境下不会报错,但是返回的数据不正确。
则该内存我们就不能将其当作AA的实例使用,此时就需要用到显式构造函数调用:
AA * aa = new(ptr)AA();
则AA的构造函数被唤起,完成实例的构造。
但是在某些特殊用法下开发人员需要调用构造函数来完成,对象实例的生成。
例如:在memory pool编程中,预先申请一块大的普通内存,在使用过程中需要将其中的一小块转换为一个对象实例,
在这种场景下就需要显式调用构造函数。
定义class AA:
class AA { public: AA() {printf("hello AA:AA();/n"); temp = 10;}; virtual ~AA() {}; int GetI(){ return temp;}; private: int temp; };我们预先申请一块内存:
char * ptr = (char *)malloc(sizeof(AA));
在需要的时候我们需要将ptr转换成AA的对象实例,如果采用如下方式调用:
AA * aa = (AA *)ptr;
那么class AA的构造函数不会被唤起,则这块内存还不是AA的对象实例。
此时如果作如下操作:aa->GetI();
VC6.0环境下不会报错,但是返回的数据不正确。
则该内存我们就不能将其当作AA的实例使用,此时就需要用到显式构造函数调用:
AA * aa = new(ptr)AA();
则AA的构造函数被唤起,完成实例的构造。