指针p+1移动的字节数取决于其指向类型大小,如int移4字节、char移1字节、double移8字节,因指针算术以类型大小为单位,p+n实际地址为原地址加nsizeof(T)。

当对C++中的指针 p 执行 p + 1 操作时,实际内存地址的移动量并不是简单地加1个字节,而是增加了一个与指针所指向数据类型大小相关的偏移量。
指针算术的本质
指针的算术运算是“以所指向类型的大小为单位”进行的。也就是说,p + 1 会让指针指向下一个同类型的数据元素,而不是下一个字节。
具体移动的字节数取决于指针的类型:
如果 p 是 int*,且 sizeof(int) == 4,那么 p + 1 实际地址增加 4 字节。如果 p 是 char*,且 sizeof(char) == 1,那么 p + 1 地址增加 1 字节。如果 p 是 double*,且 sizeof(double) == 8,那么 p + 1 地址增加 8 字节。
示例说明
假设有一个 int 数组和指向它的指针:
立即学习“C++免费学习笔记(深入)”;
int arr[3] = {10, 20, 30};
int* p = arr; // p 指向 arr[0]
p + 1; // 实际地址 = p + sizeof(int) = p + 4(通常)
此时 p + 1 指向 arr[1],地址比 p 多 4 个字节(在 32 位或 64 位系统中 int 通常为 4 字节)。
底层计算方式
编译器会将 p + n 转换为:
new_address = original_address + (n * sizeof(T))
其中 T 是指针所指向的数据类型。
基本上就这些。指针加1移动多少,完全取决于它是什么类型的指针。
以上就是C++指针算术运算p+1的实际内存地址移动了多少的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1475037.html
微信扫一扫
支付宝扫一扫