Golang指向接口的指针能否使用_Golang interface pointer使用限制

Go语言中不应使用*interface{},因其无实际用途且易引发错误;interface本身已具间接性,再加指针仅增复杂度;正确做法是返回新值、用具体类型或泛型替代。

Go 语言中不能直接定义或使用指向 interface 的指针,即 *interface{}*SomeInterface 是合法语法但几乎无实际用途,且极易引发误解和错误。这不是语法限制,而是语义和设计使然。

interface 本身已含“间接性”

interface 变量在底层由两部分组成:类型信息(type)和值(value)。它本身就是一种间接封装,类似“指针+元数据”的组合体。再套一层指针(*interface{})只是多了一层地址跳转,不带来新能力,反而增加复杂度。

  • var i interface{} = 42 —— i 已经能安全持有任意类型值
  • var pi *interface{} = &i —— pi 指向的是 interface 变量本身,不是它内部的值;修改 *pi 只会替换整个 interface 实例,无法修改其内部值的内容

常见误用场景与问题

开发者有时想通过 *interface{} 实现“修改传入的 interface 值”,但这往往暴露了设计偏差:

  • 函数接收 *interface{},试图在函数内让该 interface 持有新值 → 实际上只是改了局部指针所指的 interface 变量,调用方无感知(除非显式解引用并赋值)
  • 把结构体指针赋给 interface{} 后,再取其地址得到 *interface{} → 此时你拿到的是 interface 变量的地址,不是原结构体的地址,无法用于方法调用或状态更新
  • 期望 *interface{} 能像 *T 那样支持方法调用 → 不行。interface 的方法调用依赖其内部存储的类型和值,*interface{} 存储的是 interface 类型,它的方法集为空(除非你额外为 *interface{} 定义方法,这毫无意义)

真正需要“可变 interface”的替代方案

如果目标是让函数能改变调用方持有的 interface 值,应直接操作 interface 变量本身,或换用更清晰的模式:

  • 返回新 interface 值:func adjust(i interface{}) interface{},由调用方决定是否赋值
  • 用具体类型代替空接口:func adjust(s *MyStruct),明确意图且类型安全
  • 用带状态的结构体包装 interface:type Holder struct { Val interface{} },然后传 *Holder
  • 若需泛型行为,Go 1.18+ 推荐用泛型函数而非 interface{} + 指针

唯一合法但罕见的使用场景

*interface{} 在极少数底层操作中可能出现,比如:

  • 反射中临时取 interface 变量的地址做 reflect.ValueOf(&i).Elem()
  • 某些 Cgo 交互或 unsafe 场景中作为内存占位符(需极度谨慎)

但这些都不是业务代码该触碰的边界。

基本上就这些。interface 的设计哲学是“值语义 + 运行时多态”,加指针不仅没增益,还模糊了所有权和修改意图。遇到想用 *interface{} 的时候,停下来问问:是不是该换类型、改接口、或用泛型?