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

指针算术是C++中操作内存地址的核心机制,理解它的规则对高效编程很重要。指针的加减不是简单的数值运算,而是根据所指向数据类型的大小自动调整。
当你对指过去做加减操作时,编译器会根据指针所指向类型的大小来决定实际地址的偏移量。例如:
也就是说,p + n 实际对应的地址是:p + n * sizeof(类型)
假设有一个数组和指向它的指针:
立即学习“C++免费学习笔记(深入)”;
int arr[5] = {10, 20, 30, 40, 50};可以用 *(p + i) 来访问 arr[i],这和 arr[i] 或 p[i] 是等价的。
两个同类型指针相减,结果是它们之间相隔的元素个数,类型为 ptrdiff_t。
int* p1 = &arr[1];注意:只有指向同一数组(或同一对象的内存块)的指针相减才有定义意义。
以下操作是非法或未定义的:
基本上就这些。掌握指针算术的关键是记住:它始终以“元素”为单位移动,而不是字节。编译器帮你处理了地址的缩放。只要类型明确,加减自然按类型大小调整。不复杂但容易忽略。
以上就是C++指针算术怎么用 地址加减运算规则的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号