C++指针算术怎么用 地址加减运算规则

指针算术按数据类型大小调整地址偏移,如int加1前进4字节,double加1前进8字节,p+n对应p+nsizeof(类型);数组中p+i可访问arr[i],两同类型指针相减得元素个数,类型为ptrdiff_t,仅同一数组内有效;禁止指针相加、void算术及跨数组减法。

c++指针算术怎么用 地址加减运算规则

指针算术是C++中操作内存地址的核心机制,理解它的规则对高效编程很重要。指针的加减不是简单的数值运算,而是根据所指向数据类型的大小自动调整。

指针加减的本质

当你对指过去做加减操作时,编译器会根据指针所指向类型的大小来决定实际地址的偏移量。例如:

int* p; p + 1 会前进 sizeof(int) 字节(通常是4字节)double* p; p + 1 前进 sizeof(double) 字节(通常是8字节)

也就是说,p + n 实际对应的地址是:p + n * sizeof(类型)

常见指针算术操作

假设有一个数组和指向它的指针:

立即学习“C++免费学习笔记(深入)”;

int arr[5] = {10, 20, 30, 40, 50};
int* p = arr; // 指向arr[0]p + 1 → 指向 arr[1],地址增加 4 字节p + 3 → 指向 arr[3]p – 1 → 如果合法,指向前一个 int 位置

可以用 *(p + i) 来访问 arr[i],这和 arr[i] 或 p[i] 是等价的。

指针之间的减法

两个同类型指针相减,结果是它们之间相隔的元素个数,类型为 ptrdiff_t。

int* p1 = &arr[1];
int* p2 = &arr[4];
ptrdiff_t diff = p2 – p1; // 结果是 3

注意:只有指向同一数组(或同一对象的内存块)的指针相减才有定义意义。

不能进行的运算

以下操作是非法或未定义的:

两个指针相加(p + q)→ 不允许void* 上的算术 → 因为 void 没有大小,无法计算偏移跨数组的指针减法 → 可能导致未定义行为

基本上就这些。掌握指针算术的关键是记住:它始终以“元素”为单位移动,而不是字节。编译器帮你处理了地址的缩放。只要类型明确,加减自然按类型大小调整。不复杂但容易忽略。

以上就是C++指针算术怎么用 地址加减运算规则的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1472331.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月18日 19:31:49
下一篇 2025年12月18日 19:31:58

相关推荐

发表回复

登录后才能评论
关注微信