C++ 奇淫巧计:如何用一行代码算出 Class 或者 Struct 里成员变量的内存偏移?

直接代码:

#include <iostream>
#include <string>

struct Vector3
{
	float x, y, z;
};

int main()
{
	int offset = (int)&((Vector3*)nullptr)->x;
	std::cout << offset << std::endl;

	std::cin.get();
}

解析

nullptr 相当于 0 ,解释为 Vector3* 指针之后,此指针编译器理解成在地址 0 处分配的 Vector3 指针。
此时由 nullptr->x 即是 0 + x-offset 。
将此地址用 & 取值转换为 int 后即可输出,注意不可直接转换 (int)(null-ptr->x),原因后面会讲到。

what do we learn?

  • 空指针本身的操作不会引起 crash,引起 crash 的是尝试解引用,比如 *nullptr 或是 nullptr->x。而只是对 nullptr->x 进行取地址运算,并没有引起解引用,因而不会 crash。
  • 这个技巧省去看 Momery 的窗口来分析成员内存分布,试试看把 y 的类型改成 char,并输出 z 的 offset,看看是 5 还是 8 ?为啥?
  • 类型从来是语言编译期的约定,在计算机底层只有内存,至于内存怎么解释、怎么解读,才是我们的编译逻辑。比如上面的各种类型骚操作,不涉及具体内存的操作,而仅仅是在操作 “C++ 类型规则本身”。
  • 4
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值