C++中this是隐式传入的非空指针,nullptr调用成员函数会导致未定义行为;因其直接参与成员变量偏移计算和虚表指针读取,解引用空地址将引发段错误或崩溃。

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









