我相信我對(duì)正常用例中的 defer 理解得很好。比如這個(gè)問(wèn)題中列出的Golang defer 行為。但是,我對(duì)在不返回的 goroutine 中調(diào)用 defer 時(shí)發(fā)生的事情感到有些困惑。這是有問(wèn)題的代碼。func start_consumer() { conn, _ := amqp.Dial("amqp://username:password@server.com") //defer conn.Close() ch, _ := conn.Channel() //defer ch.Close() q, _ := ch.QueueDeclare( "test", // name true, // durable false, // delete when unused false, // exclusive false, // no-wait nil, // arguments ) _ = ch.Qos( 3, // prefetch count 0, // prefetch size false, // global ) forever := make(chan bool) go func() { for { msgs, _ := ch.Consume( q.Name, // queue "", // consumer false, // ack false, // exclusive false, // no-local false, // no-wait nil, // args ) for d := range msgs { log.Printf("Received a message: %s", d.Body) d.Ack(true) } time.Sleep(1 * time.Second) } }() log.Printf(" [*] Waiting for messages. To exit press CTRL+C") <-forever}這個(gè)函數(shù)是從go start_consumer()這可能是我對(duì)通道如何工作的誤解,但我雖然永遠(yuǎn)不會(huì)返回,因?yàn)樗诘却齻鬟f給它的值。
1 回答

慕碼人2483693
TA貢獻(xiàn)1860條經(jīng)驗(yàn) 獲得超9個(gè)贊
上一個(gè)問(wèn)題中引用的 Go 博客的Defer、Panic 和 Recover帖子很好地解釋了 defer 語(yǔ)句的工作原理。
defer 語(yǔ)句將函數(shù)調(diào)用推送到列表上。保存的調(diào)用列表在周圍函數(shù)返回后執(zhí)行。Defer 通常用于簡(jiǎn)化執(zhí)行各種清理操作的函數(shù)。
在您的情況下,由于 goroutine 不返回,因此永遠(yuǎn)不會(huì)運(yùn)行延遲調(diào)用列表。這使得 defer 語(yǔ)句在這種情況下是不必要的。
- 1 回答
- 0 關(guān)注
- 235 瀏覽
添加回答
舉報(bào)
0/150
提交
取消