Golang 返回函数



谁能解释为什么打印 0 和 1 而不是其他任何东西?谢谢!

func makeFunction(name string) func() {
    fmt.Println("00000")
    return func() {
        makeFunction2("abcef")
    }
}
func makeFunction2(name string) func() {
    fmt.Println("11111")
    return func() {
        makeFunction3("safsf")
    }
}
func makeFunction3(name string) func() {
    fmt.Println("33333")
    return func() {
        fmt.Printf("444444")
    }
}
func main() {
    f := makeFunction("hellooo")
    f()
}

谁能解释为什么打印 0 和 1 而不是其他任何东西?谢谢!

让我们按照程序流程:

  1. main开始了。
  2. main打电话给makeFunction.
  3. makeFunction打印00000,并返回一个匿名函数。
  4. 回到main,我们调用上一次调用返回的匿名函数。
  5. 匿名函数调用makeFunction2
  6. makeFunction2打印11111,并返回一个匿名函数。
  7. main返回。

由于返回值是在上述步骤 6 之后丢弃的,因此不会打印任何其他内容。

让我们看看你的main

1号线

f := makeFunction("hellooo")
  • 副作用:打印"00000">
  • 返回值:执行makeFunction2("abcef")的匿名函数,分配给标识符f

2号线

f()

相当于:

_ = f()
  • 副作用:打印"11111">
  • 返回值:执行makeFunction3("safsf")的匿名函数,丢弃(你没有分配f()的返回值(。

makeFunction3永远不会分配给任何标识符,也永远不会调用。

要打印 3,您必须调用两次:

f()()

要打印 4,只需执行以下操作:

f()()()

因为。。。

// prints "00000" and returns a function that if run
// will invoked `makeFunction2`
f := makeFunction("hello")
// `makeFunction2` is called, printing "11111" and returns 
// a function that if run will invoked `makeFunction3`
f1 := f()
// `makeFunction3` is called, printing "33333" and returns
// a function that if run will invoked `makeFunction4`
f2 := f1()

测试题,如果你这样做,它会打印出什么?

f := makeFunction("Hello")()()
f()

这称为 currying 或闭包,但在您的示例中,您没有关闭任何局部值,因此后者失去了意义。

makeFunction只返回函数makeFunction2。 因为这不是递归函数。如果您希望表现得像递归函数,那么您应该将返回 func(({} 更改为 (return makeFunction2 或 3(

func makeFunction(name string) func() {
    fmt.Println("00000")
    return makeFunction2("abcef")
}
func makeFunction2(name string) func() {
    fmt.Println("11111")
    return makeFunction3("safsf")
}
func makeFunction3(name string) func() {
    fmt.Println("33333")
    return func() {
        fmt.Printf("444444")
    }
}
func main() {
    f := makeFunction("hellooo")
    f()
}
// Output: 
00000
11111
33333
444444

原因是它只返回匿名功能。

package main
import "fmt"
func makeFunction(name string) func() {
    fmt.Println("00000")
    return func(){
        makeFunction2("abcef")()
    }
}
func makeFunction2(name string) func() {
    fmt.Println("11111")
    return func() {
        makeFunction3("safsf")()
    }
}
func makeFunction3(name string) func() {
    fmt.Println("33333")
    return func() {
        fmt.Printf("444444")
    }
}
func main() {
    f := makeFunction("hellooo")
    f()
}

最新更新