Go语言禁止普通指针算术运算是出于安全考虑:防止内存越界、确保GC可追踪、维持零成本抽象;真需偏移必须经unsafe.Pointer中转uintptr,且不可长期持有。

Golang指针可以进行运算吗_指针操作限制解析

Go 语言中,*int*string 等普通指针**完全不能进行算术运算**——p + 1p - qp++ 全部编译报错。

为什么普通指针禁止加减?安全是硬约束

这不是疏漏,而是 Go 编译器主动拦截的保护机制。C/C++ 中常见的指针偏移,在 Go 里被设计为“不可表达”,原因很实在:

真要偏移地址?只能走 unsafe.Pointer

当你在写序列化库、解析二进制协议、或对接 C 代码时,确实需要字节级操作。这时唯一合法路径是:unsafe.Pointer → 转 uintptr → 加减 → 转回 unsafe.Pointer

package main

import ( "fmt" "unsafe" )

func main() { arr := [3]int{10, 20, 30} p := unsafe.Pointer(&arr[0]) // 获取首元素地址 size := unsafe.Sizeof(arr[0])

// 指向第 2 个元素(索引 1)
p2 := (*int)(unsafe.Pointer(uintptr(p) + size))
fmt.Println(*p2) // 输出 20

}

日常开发该用什么替代指针运算?

99% 的场景下,你根本不需要指针算术。Go 提供了更安全、更直观的替代方式:

真正容易被忽略的是:哪怕你用了 unsafe,只要涉及跨 goroutine 写内存、或把 uintptr 存成全局变量,就可能绕过 Go 的内存模型保证,引发竞态或静默崩溃。安全边界不在语法层,而在你是否全程掌控地址生命周期。

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。