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

指针算术是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 没有大小,无法计算偏移
- 跨数组的指针减法 → 可能导致未定义行为
基本上就这些。掌握指针算术的关键是记住:它始终以“元素”为单位移动,而不是字节。编译器帮你处理了地址的缩放。只要类型明确,加减自然按类型大小调整。不复杂但容易忽略。