Go函数是一等公民但需显式声明完整签名,func(int,string)bool与func(string,int)bool不兼容,返回多值须用括号,传参或返回时签名必须严格匹配,函数不可作map键,闭包需注意内存生命周期。
Go 语言里函数是一等公民,能赋值给变量、作为参数传入、也能作为返回值返回——但必须显式声明类型,不能靠推导,这点和 JavaScript 或 Python 不同。
Go 中没有 function 或 func() 这样的通用类型关键字;每个函数类型都是独立的、由签名定义的类型。写错签名(比如参数顺序、指针与否、error 位置)就完全不兼容。
func(int, string) bool 和 func(string, int) bool 是两个不同类型func(*http.Request) error 不能赋给 func(http.Request) error
func() (int, error) ≠ func() int, error(后者语法错误)常见于回调、策略模式或中间件场景。接收方需明确写出函数类型签名,不能只写 func。
func applyOperation(x, y int, op func(int, int) int) int {
return op(x, y)
}
result := applyOperation(3, 4, func(a, b int) int {
return a * b
}) // result == 12
func(int, int) int
applyOperation(3, 4, add),前提是 func add(int, int) int 已定义func(int, int) (int, error),调用处也要同步处理返回值返回函数时,返回类型写在最后,且必须带完整签名;返回的函数体里可捕获外层变量(闭包),但要注意生命周期。
立即学习“go语言免费学习笔记(深入)”;
func makeMultiplier(factor int) func(int) int {
r
eturn func(x int) int {
return x * factor
}
}
double := makeMultiplier(2)
triple := makeMultiplier(3)
fmt.Println(double(5)) // 10
fmt.Println(triple(5)) // 15
func(int) int,不是 func() int 或其他factor 被闭包捕获,即使 makeMultiplier 返回后,double 仍能访问它函数类型在 interface、map 键、结构体字段中使用时,约束比想象中更严。
map[func(int) int]string 编译失败(函数不可比较)OnSuccess func(id int, err error) 比 func(int, error) 更易读http.HandlerFunc 是 func(http.ResponseWriter, *http.Request) 的别名,直接传 func(*http.Request, http.ResponseWriter) 会编译报错go vet 或 IDE 提示能早发现函数类型本身不复杂,但 Go 的强类型让每处签名都得对得上;少一个 *、多一个 error、参数顺序颠倒,都会导致编译失败,而且错误信息未必直指根源。写的时候慢一点,把签名抄清楚,比事后调试快得多。