Go 大佬良心發(fā)現(xiàn),愿意給 Map 加清除了?
大家好,我是煎魚。
一個東西來來回回的討論,關(guān)了又開,關(guān)了后建新的,新的被 ban 了,又發(fā)現(xiàn)新的論據(jù),再打開新的。這在職場工作中很常見,在 Go 的提案討論中,也出現(xiàn)了...
今天要分享的是 Go map 在 NaN 上的一個爭議和可能即將出現(xiàn)的 API 增加。
背景和考題
NaN 是什么
在計算機科學(xué)中,有一個神奇的值,叫做:NaN(Not a Number,非數(shù))。它是數(shù)值數(shù)據(jù)類型的一類值,表示未定義或不可表示的值。常在浮點數(shù)運算中使用。首次引入 NaN 的是 1985 年的 IEEE 754 浮點數(shù)標(biāo)準(zhǔn)。
在與 NaN 值的存儲和比較時,會有問題。因為判斷一個值是否為 NaN 時,不能通過判斷 x=NaN 或 x≠NaN 來進行比較。但因為 NaN 永遠不等于其自身,因此可通過判斷 x=x 或 x≠x 來判斷 x 是否為 NaN 值,將會分別返回 False 和 True。
當(dāng) NaN 與另一個浮點數(shù) x(其中 x 可為正常值、正負(fù)無窮大或 NaN)進行比較時,比較結(jié)果如下:
比較 | 結(jié)果 |
NaN ≥ x | False |
NaN ≤ x | False |
NaN > x | False |
NaN < x | False |
NaN = x | False |
NaN ≠ x | True |
這里的理解對于下面的考題很重要。
Go IEEE-754 考題
在 Go101 上看到一道關(guān)于 IEEE-754 浮點數(shù)的題,我這里引用題目,以下代碼輸出什么?
如下代碼:
- A:true true。
- B:true false。
- C:false false。
- D:false true。
答案是啥?是 A 嗎,還是 D?
對上述程序進行解析,變量 x,y 是 +Inf 正無窮。m,n 是 NaN 無窮值。
正確的答案是:B。
你答對了嗎?
提案
在對 NaN 有了基本的了解后,我們可以正式進入主題了。在 Go map 關(guān)聯(lián)提案中,常提到新增 API,用于滿足清空 map 的訴求:
但在多次討論中,Go 官方團隊給出的解決方案是:
并關(guān)閉了相關(guān)的提案,結(jié)束了這個議題。留下滿臉 ”好吧,這都行“ 的疑惑打工人的我們,這是這類提案的背景。
但這塊有一個坑,在包含任何 NaN 鍵值時,將無法通過循環(huán) delete 的方式清空 map。一旦你 map 有 NaN,但你又 for+delete,以為刪掉了,其實并沒有,就會產(chǎn)生類似泄露的效果。
因此 Go 團隊的靈魂人物 Russ Cox,重新發(fā)起了新提案《proposal: spec: add delete(m) to clear map[1]》。如下圖:
希望借此來解決 map 在 NaN 的問題,并同時完成一直以來討論的 map 清空/重置/清理等社區(qū)訴求。
也就是新增,如下特性:
支持清除 map 的功能(即使包含 NaN)。
總結(jié)
針對這個提案也有幾種聲音,分別是萬惡的命名,對叫 delete,還是叫 clear 都有著不同的見解。
也有聲音提到不允許引入 NaN 值,但顯然。在 Go1 已經(jīng)很難了,因為 NaN 已經(jīng)被允許引入,球已經(jīng)在鍋里了。
對于 map 新增 API 用于清空/重置/清除的作用,你怎么看呢?還是說你也更喜歡對 NaN 單獨的處理?例如 panic?
參考資料
[1]proposal: spec: add delete(m) to clear map: https://github.com/golang/go/issues/56351