精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

業內大佬怒噴:Go 正朝著錯誤的方向發展

開發 前端
Go 開始朝著增加復雜性和隱式代碼執行的方向發展。也許我們需要停止添加增加 Go 復雜性的特性,而應該專注于 Go 的基本特性 - 簡單性、生產力和性能。

大家好,國外知名開源大佬 Aliaksandr Valialkin[1],最近針對即將正式發布的 Go1.23 中的迭代器寫了篇文章[2]怒噴。引起了巨大的社區熱議。

迭代器這一新特性,有認同也有否定。無論怎么說,Go 新的復雜度來了。今天分享他針對 Go 在 rsc 當權后的現狀的看法和對迭代器的不滿等看法的文章。

本文原作者 Aliaksandr Valialkin 是 vm、quicktemplate、fastjson、fasthttp、fastcache、easyproto 等的開發者,也算是較為資深的 Go 工程師了。

Go 編程語言因其易用性而廣為人知。歸功于其精心設計的語法、特性和工具,Go 使得編寫任意復雜度的易于閱讀和維護的程序成為可能(詳見 GitHub)。

圖片圖片

然而,一些軟件工程師稱 Go 為 “無聊”和 “過時”,因為它缺少像:monads、option types、LINQ、borrow checkers、零開銷抽象、面向方面編程、繼承、函數和運算符重載等特性。

雖然這些特性可能簡化特定領域的代碼編寫,但它們除了帶來好處之外,還有額外的成本。

這些特性通常對腦力鍛煉有好處。但在處理生產代碼時,我們不需要額外的心理負擔,因為我們已經忙于解決業務任務。

所有這些特性的主要成本是:

  • ? 僅僅通過閱讀代碼,就更難理解發生了什么;
  • ? 調試這樣的代碼變得更加困難,因為需要跳過數十個非平凡的抽象才能到達業務邏輯;
  • ? 由于這些特性施加的限制,向這樣的代碼添加新功能變得更加困難。

這可能會顯著減慢甚至停止代碼開發的步伐。這就是 Go 最初沒有這些特性的主要原因。

泛型在 Go1.18 中的引入

不幸的是,這些特性開始出現在最近的 Go 版本中:

泛型已經在 Go1.18 中添加。許多軟件工程師希望在 Go 中添加泛型,因為他們認為這將顯著提高他們在 Go 中的生產力。

自 Go1.18 發布以來已經過去了兩年,但生產力提高的跡象并不明顯。Go 中泛型的總體采用率仍然很低。

為什么?因為在大多數實際的 Go 代碼中并不需要泛型。

另一方面,泛型顯著增加了 Go 語言本身的復雜性。例如,嘗試理解泛型添加后 Go 類型推斷的所有細節。它的復雜性已經非常接近 C++ 類型推斷了。

Go 泛型還缺少 C++ 模板中存在的基本特性,例如,Go 泛型不支持泛型類型中的泛型方法。它們也不支持模板特化和模板模板參數,以及許多其他特性,這些特性需要充分利用泛型編程。

Go 1.23 中的迭代器

Range over functions(范圍函數),即迭代器、生成器或協程,將在 Go 1.23 中被添加。讓我們更仔細地看看這個 “特性”。

如果你不熟悉 Go 中的迭代器,那么請閱讀這篇介紹[3]。

本質上,這是一種語法糖,允許在具有特殊簽名的函數上編寫 for ... range 循環。這聽起來像是一個很棒的特性,不是嗎?讓我們嘗試弄清楚這個特性解決了什么實際問題。

在 Go 中,沒有一種標準的方式來遍歷一系列值。由于缺乏任何約定,最終出現了各種各樣的方法。

每種實現都做了在當時的上下文中最有意義的事,但孤立的決策導致了用戶的困惑。

以下是一些標準庫中存在的不同迭代方式:

? archive/tar.Reader.Next

? bufio.Reader.ReadByte

? bufio.Scanner.Scan

? container/ring.Ring.Do

? database/sql.Rows

? expvar.Do

? flag.Visit

? go/token.FileSet.Iterate

? path/filepath.Walk

? runtime.Frames.Next

? sync.Map.Range

這些函數在迭代的細節上幾乎沒有一致性。即使在簽名上達成一致的函數也不總是同意語義。

例如,大多數返回 (bool, T) 的迭代函數遵循 Go 的常規,即第一個 bool 表示第二個 T 是否有效。

與此相反,runtime.Frames.Next 返回的 bool 表示迭代是否繼續。

當你想要遍歷某些內容時,你首先必須了解你正在調用的特定代碼如何處理迭代。這種不一致性阻礙了 Go 的目標,即在大型代碼庫中輕松移動。

人們經常提到所有 Go 代碼看起來都差不多是一種優勢。但對于具有自定義迭代的代碼來說,這根本不是真的。

同理,這聽起來是合理的 - 在 Go 中有一種統一的方式來遍歷各種類型。但是,關于向后兼容性,Go 的主要優勢之一呢?

所有上述標準庫中的現有自定義迭代器將根據 Go 兼容性規則永遠保留在標準庫中。

因此,所有新的 Go 版本將至少提供兩種不同的方式,在標準庫中遍歷各種類型 - 舊的方式和新的方式。

這增加了 Go 編程的復雜性,因為:

  • ? 你需要知道遍歷各種類型時的兩種方式,而不是單一的方式。
  • ? 你需要能夠閱讀和維護使用舊迭代器的舊代碼,以及可能使用舊迭代器或新迭代器,或同時使用兩種迭代器類型的新代碼。
  • ? 當你編寫新代碼時,需要選擇適當的迭代器類型。

Go 1.23 中迭代器的其他問題

直到 Go 1.23,for ... range 循環只能應用于內置類型:int(自 Go1.22 起)、string、slice、map 和 channel。

這些循環的語義清晰易懂(channel 的循環語義更復雜,但如果你處理并發編程,那么你應該很容易理解)。

for ... range 循環現在可以應用于函數,這引入了一種新形式的迭代器,稱為 pull 和 push 函數。

這使得不可能理解給定的無辜循環體 for ... range 實際上在背后做什么,因為它隱式地將循環體包裝在一個匿名函數中,并將其傳遞給 push 迭代器函數。此外,它隱式地調用匿名 pull 函數,并將返回的結果傳遞給循環體。

這還隱式地轉換了 return、continue、break、goto 和 defer 語句為匿名函數內的非顯式語句。

以下是一些示例代碼,展示了新迭代器的使用和潛在問題:

// 舊的顯式回調方法
tree.walk(func(k, v string) { println(k, v) })

// 新的 range over function 方法
for k, v := range tree.walk { println(k, v) }

請記住,后面的循環隱式地轉換為帶有顯式回調調用的前一個代碼。現在讓我們從循環中返回一些東西:

for k, v := range tree.walk {
  if k == "foo" {
    return v
  }
}

它隱式地轉換為類似于以下內容的難以追蹤的代碼:

var vOuter string
needOuterReturn := false

tree.walk(func(k, v string) bool {
  if k == "foo" {
    needOuterReturn = true
    vOuter = strings.Clone(v) // 這里進行了內存分配和復制
    return false
  }
})

if needOuterReturn {
  return vOuter
}

如果 tree.walk 通過從字節切片的不安全轉換將 v 傳遞給回調,那么 v 的內容可能在下一次循環迭代中改變。因此,隱式生成的防彈代碼必須使用 strings.Clone(),這可能導致不必要的內存分配和復制。

range over func 特性對函數簽名施加了限制。這些限制并不適合所有需要迭代集合項的情況。

這迫使軟件工程師在 for ... range 循環的丑陋 hack 和編寫理想適合給定任務的顯式代碼之間做出艱難選擇。

結論

遺憾的是,Go 開始朝著增加復雜性和隱式代碼執行的方向發展。也許我們需要停止添加增加 Go 復雜性的特性,而應該專注于 Go 的基本特性 - 簡單性、生產力和性能。

例如,最近 Rust 開始在性能關鍵領域取代 Go 的份額。我相信如果 Go 核心團隊專注于熱點循環的優化,如循環展開和 SIMD 使用,這種趨勢可以逆轉。

這不應該太影響編譯和鏈接速度,因為只有一小部分編譯的 Go 代碼需要優化。沒有必要優化所有變體的愚蠢代碼 - 這些代碼即使在優化熱點循環之后,仍然會很慢。

只優化軟件工程師有意編寫的特定模式就足夠了,他們關心他們的代碼性能。

Go 比 Rust 更容易使用。我們為什么要在性能競賽中輸給 Rust?

另一個 Go 可以在不增加語言本身復雜性和使用這些特性的 Go 代碼復雜性的情況下獲得的有用特性的例子,是類似于這個的小生活質量改進。

我是誰?

我是 VictoriaMetrics、quicktemplate、fastjson、fasthttp、fastcache、easyproto 等的開發者。感謝 Go,我一直在嘗試遵循 KISS 設計原則。

引用鏈接

[1] Aliaksandr Valialkin: https://github.com/valyala

[2] 文章: https://itnext.io/go-evolves-in-the-wrong-direction-7dfda8a1a620

[3] 介紹: https://bitfieldconsulting.com/posts/iterators

責任編輯:武曉燕 來源: 腦子進煎魚了
相關推薦

2017-02-09 15:00:06

Windows 10 微軟Tim Sweeney

2019-10-12 17:31:34

物聯網技術電腦

2020-12-15 11:43:56

人工智能教育智能化

2025-07-10 08:22:50

2010-04-22 12:17:15

2022-09-14 17:53:45

ASR技術領域

2022-08-30 15:26:07

AI語音識別

2016-10-08 13:33:05

安尚云云計算MoPaaS

2022-02-21 06:07:58

勒索軟件網絡安全漏洞

2010-09-09 17:32:50

2010-09-16 13:03:45

2022-02-17 11:00:19

零日漏洞漏洞網絡安全

2013-01-05 02:33:01

JavaJava語言Java發展方向

2020-07-20 14:42:27

技術資訊

2023-02-20 15:12:50

特斯拉自動駕駛

2025-06-09 09:35:56

2014-01-13 09:58:14

大佬預測2014

2019-10-14 15:14:17

存儲云存儲人工智能

2009-10-14 15:06:22

IT職業發展

2022-11-10 10:14:12

人工智能
點贊
收藏

51CTO技術棧公眾號

啪啪小视频网站| ass精品国模裸体欣赏pics| 成人免费在线| www.亚洲色图| 国产精品成人av性教育| 日韩欧美在线视频播放| 成人h动漫精品一区二区器材| 午夜精品一区在线观看| 日韩三级电影免费观看| hs视频在线观看| 亚洲欧美视频| 欧美xxxx做受欧美.88| 在线免费观看a级片| 国内精品伊人| 欧美视频裸体精品| 日本女人高潮视频| 国产中文字幕在线观看| 国产黄人亚洲片| 国产精品久久久| 国产精品成人久久| 999国产精品999久久久久久| 日韩av影片在线观看| 亚洲一二三av| 成人国产综合| 狠狠操狠狠色综合网| 美女在线免费视频| 香蕉视频在线播放| 久久久久久久久久久电影| 91久久精品国产91久久性色tv| 国产精品尤物视频| 国产毛片久久| 性欧美长视频免费观看不卡| 老湿机69福利| 久久久久久久久久久9不雅视频| 亚洲女人被黑人巨大进入| 中文字幕亚洲日本| 久久国际精品| 制服丝袜av成人在线看| 国产精品宾馆在线精品酒店| www欧美xxxx| 一区二区三区在线看| 一区二区三区久久网| av女优在线| 国产女主播视频一区二区| 鲁鲁视频www一区二区| 人人妻人人玩人人澡人人爽| 国产二区国产一区在线观看| 91久久国产精品91久久性色| 亚洲一区在线观| 青草av.久久免费一区| 国产成人亚洲精品| www.亚洲激情| 老司机午夜精品99久久| 国产精品视频xxx| 在线中文字幕网站| 国内精品在线播放| 91精品在线观看视频| 91好色先生tv| 国产激情一区二区三区| 成人欧美一区二区| 日本高清视频免费看| 99久久免费视频.com| 久久伊人一区| av资源种子在线观看| 国产精品久久毛片| 少妇熟女一区二区| 青青在线视频| 五月婷婷激情综合| 99精品人妻少妇一区二区 | 亚洲资源在线观看| 成人免费毛片在线观看| 高潮在线视频| 在线观看91精品国产入口| 欧美精品aaaa| 成人免费91| 亚洲аv电影天堂网| 波多野结衣福利| 久久精品99久久无色码中文字幕| xxx成人少妇69| 欧美精品一区二区蜜桃| 亚洲大胆av| 国产精品福利久久久| 一级片在线观看视频| 国产高清在线精品| 欧美日韩日本网| 大地资源网3页在线观看| 亚洲风情在线资源站| 蜜臀av午夜一区二区三区| 久久av日韩| 精品国产a毛片| 摸摸摸bbb毛毛毛片| 欧美阿v一级看视频| 91sa在线看| 国产内射老熟女aaaa∵| 99精品视频在线观看免费| 日韩精品无码一区二区三区| 羞羞电影在线观看www| 日韩欧美在线观看视频| www.五月天色| 亚洲国产网址| 色综合天天综合网国产成人网| 看片网址国产福利av中文字幕| 蜜臀久久99精品久久久久久9| av免费精品一区二区三区| 久草视频在线看| 亚洲午夜精品17c| 182午夜在线观看| 精品网站aaa| 久久在精品线影院精品国产| 黄色片中文字幕| 国产伦精品一区二区三区免费 | 91久久精品国产91久久性色| 天堂在线观看av| 亚洲欧洲中文日韩久久av乱码| 少妇性饥渴无码a区免费| 成人豆花视频| 中文字幕久久亚洲| 97人人澡人人爽人人模亚洲| 国产剧情一区在线| 亚洲国产精品123| 性感女国产在线| 精品99一区二区三区| 国产又粗又硬又长又爽| 日韩电影在线看| 精品综合久久| 日韩影视在线| 欧美福利一区二区| 潮喷失禁大喷水aⅴ无码| 香蕉精品999视频一区二区| 国产精品二区三区| 亚洲制服国产| 欧美一区二区国产| 欧美做爰啪啪xxxⅹ性| 欧美96一区二区免费视频| 免费观看国产成人| 免费v片在线观看| 亚洲福利视频二区| 国产一级做a爱免费视频| 国产精品一二二区| 久久久久久久久久久久久国产| 成人全视频在线观看在线播放高清| 亚洲片在线资源| www.中文字幕在线观看| 99国产精品视频免费观看| 免费看又黄又无码的网站| 国产精品调教视频| 91国产视频在线| 香蕉视频国产在线| 五月婷婷久久综合| 亚洲国产精品无码久久久久高潮 | 最新国产の精品合集bt伙计| 在线观看亚洲色图| 五月激情久久久| 91色精品视频在线| 亚洲综合影视| 亚洲高清久久久久久| 日韩手机在线观看| 久久久精品国产免费观看同学| 国产成人久久777777| 欧美日韩水蜜桃| 国产欧美日韩视频| 成人在线网址| 亚洲白虎美女被爆操| 二区视频在线观看| 中文字幕免费一区| 在线视频日韩欧美| 亚洲国产专区校园欧美| 欧美成熟毛茸茸复古| 日本精品另类| 美女视频黄免费的亚洲男人天堂| 亚洲国产日韩在线观看| 欧美日韩国产中文精品字幕自在自线| 日韩精品卡通动漫网站| 六月丁香婷婷久久| www.男人天堂网| 亚洲精品亚洲人成在线观看| 国产欧美精品日韩精品| av大全在线| 亚洲欧美一区二区三区四区| 在线亚洲欧美日韩| 亚洲a一区二区| 蜜桃传媒一区二区亚洲| 国产一区啦啦啦在线观看| 国内精品视频一区二区三区| 国产精品片aa在线观看| 成人黄色片在线| 欧美调教sm| 久久久99久久精品女同性| 女人18毛片一区二区三区| 高跟丝袜欧美一区| www.99re7| 久久久精品影视| 伊人影院在线观看视频| 三级在线观看一区二区| 日韩视频 中文字幕| 天海翼亚洲一区二区三区| 91精品国产自产在线| 黄色视屏在线免费观看| 日韩最新在线视频| 涩涩视频在线观看免费| 制服.丝袜.亚洲.另类.中文| 91看片在线播放| 亚洲麻豆国产自偷在线| 公肉吊粗大爽色翁浪妇视频| 成人午夜电影网站| 精品久久久99| 日韩精品久久理论片| 免费av手机在线观看| 四季av一区二区三区免费观看| 精品卡一卡二| 日本在线一区二区三区| 国产精品日韩久久久久| 国产激情视频在线看| 久久综合国产精品台湾中文娱乐网| 青青青草原在线| 日韩欧美综合在线| 91成人在线免费| 欧美四级电影网| 好看的av在线| 亚洲成人av电影| 免费无码毛片一区二区app| 国产精品久久99| 日本理论中文字幕| 久久久久久久久久久久久久久99| 亚洲天堂av网站| 国产成人丝袜美腿| 天堂网成人在线| 激情图区综合网| 欧美日韩中文不卡| 日本不卡高清视频| 免费男同深夜夜行网站| 美女精品在线| 精品久久久久久久免费人妻| 羞羞答答国产精品www一本| 国产精品www在线观看| 欧美特黄一区| 国产爆乳无码一区二区麻豆 | 久久久五月婷婷| 亚洲男女在线观看| 成人免费av网站| 国产午夜在线一区二区三区| 粉嫩av一区二区三区粉嫩| 无码人妻丰满熟妇区毛片蜜桃精品| 久久99久久久久| 五月天国产视频| 国产精品系列在线观看| 色欲无码人妻久久精品| 国产寡妇亲子伦一区二区| 少妇极品熟妇人妻无码| 懂色av噜噜一区二区三区av| 91porn在线| 99久久国产免费看| 久久久久久国产精品无码| 2020国产成人综合网| 受虐m奴xxx在线观看| 国产日韩欧美一区二区三区综合| 日本少妇xxxxx| 中文字幕一区不卡| 免费又黄又爽又色的视频| 午夜精品123| 日韩欧美在线观看免费| 欧美视频日韩视频在线观看| 亚洲天堂中文字幕在线| 日韩小视频在线观看专区| 亚洲国产精品一| 精品调教chinesegay| 触手亚洲一区二区三区| 色婷婷综合成人av| 肉肉视频在线观看| 人妖精品videosex性欧美| 97成人超碰| 国产高清在线精品一区二区三区| 日韩极品在线| 亚洲国产精品综合| 欧美日韩精品免费观看视频完整| 毛片在线播放视频| 日韩精品乱码免费| 麻豆免费在线观看视频| 久久夜色精品一区| 青花影视在线观看免费高清| 午夜久久久久久电影| 波多野结衣电车| 日韩一区二区视频| 欧美成人片在线| 欧美成人亚洲成人| gay欧美网站| 92福利视频午夜1000合集在线观看| 里番精品3d一二三区| 亚洲国产精品123| 制服诱惑一区二区| av在线免费看片| 久久午夜免费电影| 欧美日韩在线观看成人| 狠狠做深爱婷婷久久综合一区| 国产精品一区二区人人爽| 亚洲第一福利视频| 欧美三级电影一区二区三区| 久久久久久午夜| 欧美少妇激情| 久久久久久久久久久久久久一区| 香蕉久久网站| 欧美精品第三页| 国产99一区视频免费| 五月婷婷六月香| 精品免费在线视频| 国产成人av免费看| 中文字幕日韩av| 在线观看爽视频| www.成人av| 亚洲女同另类| 亚洲欧美另类动漫| 99re亚洲国产精品| 欧美三级免费看| 欧美精品aⅴ在线视频| 免费人成在线观看网站| 欧美激情网友自拍| 国产高清亚洲| 制服诱惑一区| 日产国产高清一区二区三区| 激情综合丁香五月| 亚洲在线一区二区三区| 国产乱淫av片免费| 中文字幕国内精品| 欧美韩国亚洲| 欧美高清性xxxxhdvideosex| 亚洲美女视频在线免费观看| 日韩精品――色哟哟| 亚洲啪啪综合av一区二区三区| 一本到在线视频| 日韩最新在线视频| 麻豆久久久久| 亚洲国产一区在线| 蜜臀a∨国产成人精品| 我和岳m愉情xxxⅹ视频| 欧美午夜无遮挡| 亚洲 另类 春色 国产| 久久久久久久一| 成功精品影院| 五月丁香综合缴情六月小说| 成人午夜短视频| 亚洲欧美在线观看视频| 日韩高清不卡av| 成年美女黄网站色大片不卡| 老牛影视免费一区二区| 亚洲欧美日韩精品一区二区| 日韩网站在线播放| 色国产精品一区在线观看| 你懂的视频在线观看| 日本精品性网站在线观看| 亚洲宅男一区| 看欧美ab黄色大片视频免费| 国产精品五月天| 97视频免费在线| 九九精品视频在线| 精品视频高潮| 国产精品亚洲a| 中文字幕不卡在线观看| 一道本在线视频| 欧美肥臀大乳一区二区免费视频| 成人免费在线电影网| 国产精品沙发午睡系列| 国产日韩欧美精品在线| 在线免费观看日韩视频| 久久777国产线看观看精品| 日本xxxx裸体xxxx| 欧美激情一区二区在线| 手机av在线网站| 亚洲一卡二卡三卡四卡五卡| 刘亦菲毛片一区二区三区| 欧美亚洲国产成人精品| 国产亚洲一区二区三区不卡| 婷婷激情综合五月天| 亚洲成人av在线电影| 国产一二三在线观看| 成人国产精品免费视频| 狠狠色丁香久久综合频道| 中文字幕在线观看的网站| 欧美午夜精品久久久久久孕妇 | 亚洲视频在线观看免费视频| 超薄丝袜一区二区| 日本午夜精品久久久| 艹b视频在线观看| 亚洲精品视频观看| 欧美高清成人| 91久久国产综合久久蜜月精品| 美女精品网站| 免费中文字幕在线观看| 亚洲天天在线日亚洲洲精| 麻豆精品久久| 国产情侣av自拍| 一区二区三区中文字幕电影| 国产永久免费高清在线观看视频| 亚洲在线免费看| 久久经典综合| 国产一级黄色av| 中文字幕日韩av电影| 日韩伦理一区二区三区| 992kp免费看片| 在线视频一区二区免费| 草莓视频丝瓜在线观看丝瓜18|