亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

在 Go for 循環的 post 部分中分配如何允許此循環退出?

在 Go for 循環的 post 部分中分配如何允許此循環退出?

Go
LEATH 2023-06-05 17:38:44
我正在閱讀“The Go Programming Language”一書,并在第 5 章中遇到了一個不尋常的 for 循環語法。我已經刪減了下面的示例,但整個程序都在本書的 GitHub 頁面上。type Node struct {? ? int? ? ? ? ? ? ? ? ? ? ?NodeType? ? FirstChild, NextSibling *Node}func visit(n *Node) {? for c:= n.FirstChild; c != nil; c = c.NextSibling {? ? visit(c)? }}我腦海中的 C 解析器告訴我,它c.NextSibling總是指向 aNode或 be?nil。在那種情況下,循環要么總是中斷,要么永遠繼續。當c.NextSibling不是時nil,似乎循環正在退出,因為循環值與上一次迭代相同,但我在 Go語言規范中找不到任何東西來支持它。我已經編譯了那個程序并確認它按照書上的那樣工作。我錯過了一些基本的東西還是這里發生了其他事情?
查看完整描述

1 回答

?
人到中年有點甜

TA貢獻1895條經驗 獲得超7個贊

c.NextSibling不為 nil 時,似乎循環正在退出,因為循環值與上一次迭代相同

不確定你的意思,但是是的,你誤解了一些東西。但是for循環不是罪魁禍首。當它的繼續條件仍然為真時,它肯定不會退出。

type Node struct {

? ? NodeId? ? ? ? ? ? ? ? ? int

? ? FirstChild, NextSibling *Node

}


func visit(n *Node) {

? ? for c := n.FirstChild; c != nil; c = c.NextSibling {

? ? ? ? fmt.Printf("seeing node %d\n", c.NodeId)

? ? ? ? visit(c)

? ? }

}


func main() {

? ? c3 := &Node{NodeId: 4}

? ? c2 := &Node{NodeId: 3, NextSibling: c3}

? ? c1 := &Node{NodeId: 2, NextSibling: c2}

? ? root := &Node{NodeId: 1, FirstChild: c1}


? ? visit(root)

}

輸出


seeing node 2

seeing node 3

seeing node 4


查看完整回答
反對 回復 2023-06-05
  • 1 回答
  • 0 關注
  • 120 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號