C++中this是隐式传入的非空指针,nullptr调用成员函数会导致未定义行为;因其直接参与成员变量偏移计算和虚表指针读取,解引用空地址将引发段错误或崩溃。
因为 this 在 C++ 中本质是隐式传入的非空指针参数,编译器假定它有效;若为 nullptr,调用成员函数(尤其是访问成员变量或虚函数)会触发未定义行为,底层直接导致非法内存访问或崩溃。
C++ 成员函数在编译后实际是一个普通函数,this 是编译器自动添加的第一个参数(类型为 T*),就像:
它和普通形参一样,在函数入口处被使用。编译器不做空指针检查,也不会生成防护代码——这是程序员责任。
非静态成员变量在对象内存中按布局偏移存放。例如:
struct A { int x; double y; };this->x 实际翻译为 *((int*)((char*)this + 0)),this->y 是 *((double*)((char*)this + 4))(假设对齐)。一旦 this == nullptr,地址计算结果仍是非法地址,解引用即段错误。
含虚函数的类对象开头存储虚表指针(vptr)。调用 obj.func() 时,实际执行:
this 地址读取 vptr(如 *(void**)this)
第一步就要求 this 指向合法内存——nullptr 导致读取地址 0,现代操作系统直接触发 SIGSEGV。
有人误以为“没访问成员变量就可以传 nullptr”,这是错的:
this
this 的存在nullptr->f() 定义为未定义行为([class.mfct]/4)不复杂但容易忽略:this 不是语法糖,它是真实参与寻址与调用链的底层指针。