登录
首页 >  Golang >  Go教程

Golang双重指针详解与使用示例

时间:2025-12-31 12:48:41 175浏览 收藏

Golang不知道大家是否熟悉?今天我将给大家介绍《Golang双重指针使用教程及示例》,这篇文章主要会讲到等等知识点,如果你在看完本篇文章后,有更好的建议或者发现哪里有问题,希望大家都能积极评论指出,谢谢!希望我们能一起加油进步!

Go中没有C风格的双重指针,但允许定义**T类型,即指向指针的指针;它可用于间接修改调用方的指针变量,但需传入其地址,且因指针是值类型,不能自动修改原变量。

如何在Golang中使用双重指针_操作指向指针的指针

在 Go 中没有“双重指针”这个语法概念,Go 不支持指针的指针(即 **int 这类类型)的直接解引用或取址操作,也不允许对指针变量再次取地址来构造传统 C 风格的二级指针。但你可以通过 指向指针的变量(即 *int 类型的变量)再对其取地址,得到 **int 类型的值——这在语法上是合法的,只是需谨慎使用,且用途有限。

Go 中可以定义 **T 类型,但不能像 C 那样“间接修改指针本身”

Go 允许你声明 **int 变量,也能赋值、传递、解引用,但它和 C 的双重指针语义不同:Go 的指针是值类型,传递的是指针的副本。所以即使你有 **int,想通过它修改“外层指针变量本身”,必须确保该外层变量是可寻址的(比如是变量,而非函数返回的临时指针)。

  • **int 是一个有效的类型,表示“指向 *int 的指针”
  • 你可以用 &p(其中 p*int 类型变量)得到 **int
  • 但函数参数传入 **int 并不能自动让调用方的指针变量被修改——除非你显式传入其地址

常见用途:间接修改某个指针变量的指向

当你需要在一个函数中改变调用方持有的某个指针变量所指向的地址(即让它指向另一个新分配的值),就需要传入该指针变量的地址,也就是 **T

例如:

func updatePointer(pp **int) {
    newInt := 42
    *pp = &newInt // 让调用方的 *int 指向新地址
}
func main() {
    x := 10
    p := &x
    fmt.Println(*p) // 10
    updatePointer(&p) // 传入 p 的地址
    fmt.Println(*p) // 42
}

注意:newInt 是局部变量,这里存在逃逸风险;更安全的做法是用 new(int) 或在堆上分配。

为什么一般不推荐频繁使用 **T?

Go 鼓励清晰、直接的数据流。多数场景下,以下方式更符合 Go 习惯:

  • 返回新指针:func createInt() *int { v := 5; return &v }
  • 用结构体封装状态,避免裸指针传递
  • 需要重绑定指针时,明确返回并由调用方赋值(如 p = f(p)
  • 接口或切片等引用类型本身已具备“间接性”,通常无需再加一层指针

实际注意事项

使用 **T 时要注意:

  • 确保被解引用的指针非 nil,否则运行时报 panic:`invalid memory address or nil pointer dereference`
  • **int 不等于 “指向两个层级的内存”,它只是“指向一个指针变量的地址”,而那个变量又指向一个 int
  • goroutine 安全性不因多级指针自动提升,仍需同步保护共享指针变量
  • 反射中 reflect.Value.Addr().Addr() 可模拟类似行为,但极少必要

以上就是《Golang双重指针详解与使用示例》的详细内容,更多关于的资料请关注golang学习网公众号!

前往漫画官网入口并下载 ➜
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>