我应该将请求对象传递给 goroutine 以阻止来自通道的 for-select 循环吗?

Should I pass request object to goroutine in blocking for-select loop coming from channel?

我在代码中有以下 for-select 结构:

go func(runCh chan Caller, shutdownSignal chan bool) {
        for {
            select {
            case request := <-runCh:
                go func() {
                    w.Run(&request)
                }()
            case <-shutdownSignal:
                w.Shutdown()
                return
            }
        }
    }(runCh, shutdownCh)

这部分会不会有问题:

case request := <-runCh:
    go func() {
        w.Run(&request)
    }()

?

如果是,那为什么?

换句话说 - Using goroutines on loop iterator variables part of Common Mistakes 是否也适用于我的情况,为什么它 does/does 在这里不适用?

否(不适用于此处),每次循环迭代都有新变量(内存地址):

 case request := <-runCh:

因为这个 := 创建了一个不同于前一个的新变量,证明:

package main

import (
    "fmt"
    "time"
)

func main() {
    runCh := make(chan int, 2)
    runCh <- 1
    runCh <- 2
    for i := 1; i <= 2; i++ {
        select {
        case request := <-runCh:
            go func() {
                fmt.Println(request, &request)
                time.Sleep(200 * time.Millisecond)
                fmt.Println(request, &request)

            }()
        }
    }
    time.Sleep(500 * time.Millisecond)

}

输出(每次循环迭代中request的地址不同):

1 0xc0000b8000
2 0xc0000b8008
1 0xc0000b8000
2 0xc0000b8008

参见:0xc0000b8000 != 0xc0000b8008