不管使用memcpy()还是memset(),都只有在“classes不含任何由编译器产生的内部members”时才能运行。如果这个类声明一个或者一个以上的virtual function,或者内含一个virtual base class,那么使用这两个函数将会导致那些“被编译器产生的内部members”的初值所改写。例如下面的声明:
class Shape{
public:
//这会改变内部的vptr
Shape(){ memset(this,0,sizeof(Shape));}
virtual ~Shape();
}
编译器会将此constructor扩展的内容看起来像是这样:
//扩展后的constructor
//C++伪代码
Shape::Shape()
{
//vptr必须在使用者的代码执行前先设定妥当
_vptr_shape=_vtbl_shape;
//memset会将vptr清0
memset(this,0,sizeof(Shape));
};
所以在使用memcpy和memset的时候要注意这一点。
本文探讨了在C++中使用memcpy()和memset()函数时可能遇到的问题,特别是当涉及包含虚拟函数或虚拟基类的对象时。通过具体示例说明了这些函数如何影响编译器生成的内部成员变量,如vptr,并解释了不当使用可能导致的后果。
939

被折叠的 条评论
为什么被折叠?



