指针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移动多少,完全取决于它是什么类型的指针。









