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

揭秘Go語言中的rune:一段跨越30年的Plan 9往事與UTF-8的誕生傳奇

開發 前端
Connor Taffe的一篇精彩博文[1]以及 Go語言之父 Rob Pike 的親自確認[2],為我們揭開了一段跨越三十余年,從 Plan 9 操作系統到 UTF-8 編碼誕生,再到 Go 語言的歷史傳奇。今天,就讓我們一起,深入 rune 背后的故事。

大家好,我是Tony Bai。

作為 Gopher,我們每天都在和 rune 打交道。在 Go 語言中,它通常被解釋為“一個 Unicode 碼點”,官方文檔也說引入這個術語是為了“簡潔”。但你是否曾好奇,這個略帶神秘色彩的詞匯,究竟源自何方?僅僅是為了簡潔嗎?

最近,Connor Taffe的一篇精彩博文[1]以及 Go語言之父 Rob Pike 的親自確認[2],為我們揭開了一段跨越三十余年,從 Plan 9 操作系統到 UTF-8 編碼誕生,再到 Go 語言的歷史傳奇。今天,就讓我們一起,深入 rune 背后的故事。

一句“簡潔”,一段 Plan 9 往事

Connor文章中引用的Adam Pritchard的關于限制字符串長度[3]的文章中提到:“請注意,在 Go 中,Unicode 碼點通常被稱為‘rune’。(Go 似乎是為了簡潔而引入了這個術語。)” 而 Go 官方博客《Strings, bytes, runes, and characters in Go[4]》也說:“‘Code point’有點拗口,所以 Go 引入了一個更短的術語:rune。”

圖片圖片

Rob Pike 在 Bluesky 上的發言截圖

然而,真相遠不止于此。Rob Pike 最近在 Bluesky 上澄清(如上圖),rune 這個詞實際上是 Ken Thompson 在一次為 Plan 9 尋找一個不同于 char(用于字節)的類型名稱的頭腦風暴中“得意地”提出的,Rob Pike 當即表示贊同。更關鍵的是,Rob Pike 隨后確認,這個命名發生在 Plan 9 為 UTF 和 ISO 10646 尋找類型名稱的時期,具體是1991 年 12 月 8 日的晚上!遠早于 Unicode 和 UTF-8 的廣泛應用,也比 Go 語言的誕生早了數十年。

是的,你沒看錯,rune 的故事,始于 Plan 9,那個由貝爾實驗室傳奇人物們(包括 Rob Pike, Ken Thompson 等)創造的操作系統。Go 語言深受 Plan 9 的影響,從鏈接器架構、并發原語 channel、標識符大小寫的可見性規則,到對簡潔性的極致追求,都帶著濃厚的 Plan 9 印記。rune 便是這血脈傳承中的一環。

餐巾紙上的革命:UTF-8 的誕生傳奇

要理解 rune 在 Plan 9 中的意義,就不得不提 UTF-8 的誕生。Connor 的文章中引用了一封 Rob Pike 在 2003 年的郵件,詳細披露了這段鮮為人知的歷史,糾正了“IBM 設計 UTF-8,Plan 9 實現它”的說法。

故事發生在 1992 年 9 月左右的一個晚上,新澤西一家小餐館的餐巾紙上:

  • 緣起: Plan 9 當時使用 ISO 10646 最初的 UTF(一種16位字符編碼)來支持寬字符,但團隊對它非常不滿。Rob Pike 形容道:“UTF 太糟糕了。它有模192的算術,而且在沒有除法硬件的老 SPARC 機器上幾乎不可能高效實現。像【/*】這樣的字符串可能出現在西里爾字符中間,導致你的俄文文本變成一個 C 語言注釋。還有更多問題。它作為一種編碼根本不實用。”
  • 契機: 一天下午,X/Open 委員會的一些人(據 Rob Pike 回憶可能來自 IBM 奧斯汀)打來電話,希望 Ken 和 Rob 審查他們的 FSS-UTF (File System Safe UTF) 設計。Ken 和 Rob 意識到這是一個用他們的經驗設計一個真正優秀的標準,并讓 X/Open 將其推廣出去的機會。
  • 餐巾紙上的靈感: 他們接受了挑戰,條件是必須快速完成。于是,在那個決定性的晚餐上,Ken Thompson 在餐巾紙上構想出了 UTF-8 的位打包方案。
  • 閃電般的實現: 晚餐后回到實驗室,他們便向 X/Open 解釋了新方案,并承諾在周一前(據信是 X/Open 的重要投票日)拿出一個完整的運行系統。當晚,Ken 寫了打包和解包代碼,Rob Pike 則開始修改 C 庫和圖形庫。到周五的某個時候,Plan 9 已經完全運行在后來被稱為 UTF-8 的編碼上了。

Rob Pike 在郵件中強調,他們之所以要“另起爐灶”,是因為 FSS-UTF 缺少他們認為至關重要的特性之一:支持定位到文件或流的中間,并讀取有效字符,或處理損壞的字符。 Ken Thompson 設計的 UTF-8 完美地解決了這個問題。

對比 Ken Thompson 當時提出的 UTF-8 方案(如下圖)和 FSS-UTF,我們可以看到 UTF-8 的精妙之處:后續字節以 10 開頭,與首字節的 110、1110 等模式區分開來,確保了自同步性和對 ASCII 的兼容性。

圖片圖片

Rune 的首次亮相與演變

那么,Rune 這個詞是什么時候正式與這種新的字符表示方式聯系起來的呢?Rob Pike 在其關于 Plan 9 UTF-8 實現的論文《Hello World》中寫道:

“在語義層面上,ANSI C 允許(但并未限制)寬字符的概念,并且允許此類字符串和字符常量。我們選擇 unsigned short 作為寬字符類型。在庫中,Rune 一詞由 typedef 定義為等同于 unsigned short,并用于表示 一個Unicode 字符。”

這似乎是 Rune 作為一種特定類型名稱,用于指代 Unicode 字符(碼點)的最早文獻記錄。最初在 Plan 9 C 中,Rune 是一個 16 位無符號短整型,足以表示當時的 Unicode 基本多文種平面(BMP)。

而到了 Go 語言,rune 被定義為 int32 的別名。這是因為自 1992 年以來,Unicode 已經擴展,需要更大的空間來表示所有碼點(UCS-4 定義了 31 位碼空間)。Go 語言標準庫中的 unicode/utf8 包也定義了 UTFMax = 4,表明一個 rune 最多可以用 4 個字節的 UTF-8 編碼表示。有趣的是,在 Russ Cox 移植的 plan9 port 中,Rune 類型在 2009 年末也被修改為了 unsigned int,同樣是為了支持更廣的碼點范圍。

Ken Thompson 在最初的郵件中提到:“4、5 和 6 字節序列只是出于政治原因才存在的。我更愿意刪除它們。” 這也印證了早期設計者對編碼效率和實用性的極致追求。

Rune 的足跡:從 Plan 9 到更廣闊的世界

Rune 這個術語,并沒有止步于 Plan 9。通過 Paul Borman 的貢獻,Plan 9 的 rune 功能被整合進了 4.4 BSD。從此,rune 開始在更廣闊的 Unix 世界留下足跡:

  • FreeBSD 繼承了 4.4 BSD 的 rune 函數,盡管后來推薦使用 ISO C99 的寬字符工具。
  • Apple 的 Darwin 內核,作為 BSD 的衍生,也包含了 rune_t 類型。
  • C 標準庫實現如 newlib 也包含了源自 BSD 4.4 的 rune 功能。
  • Android 通過 plan9port 移植了 Plan 9 的 libutf,其中自然也包含了 rune。
  • 甚至,微軟的 .NET 在引入 System.Text.Rune 類型時,其靈感也明確來自 Go 語言,這在其 GitHub issue 中由 Miguel de Icaza 提及[5]。

可見,rune 這個由 Ken Thompson 靈光一閃提出的詞匯,承載著一段從貝爾實驗室 Plan 9 開始,經由 BSD 社區,最終深刻影響了包括 Go 在內的現代編程語言和操作系統的字符處理歷史。

小結:rune 不只是簡潔

通過Rob Pike的親自確認,我們應該知道,當我們今天再看到 Go 語言中的 rune 時,它不僅僅是為了“簡潔”而對“Unicode code point”的替換。它是一個承載著厚重歷史的符號,是 Go 語言設計者們深厚技術底蘊和創新精神的體現,是 Plan 9 簡潔哲學與 UTF-8 實用主義的結晶。

理解 rune 的來龍去脈,有助于我們更深刻地體會 Go 語言在文本處理、字符串操作以及 Unicode 支持方面的設計考量,也讓我們對這門語言背后的巨匠們多一份敬意。下一次,當你在 Go 代碼中寫下 rune 時,或許會想起那個在新澤西餐館餐巾紙上誕生的傳奇,以及那段跨越三十余年的 Plan 9 往事。

聊一聊:

  • 在了解了 rune 的歷史后,你對 Go 語言的設計是否有新的認識?
  • UTF-8 誕生的故事中,有哪些細節讓你印象深刻?
  • 你認為這種對歷史淵源的挖掘,對我們理解和使用一門編程語言有何幫助?

歡迎在評論區分享你的看法!如果你覺得這篇文章有趣且有價值,也請轉發給你身邊的 Gopher 朋友們,讓更多人了解 rune 背后的故事。

參考資料

[1] Connor Taffe的一篇精彩博文: https://connor.zip/posts/2025-05-03-rune

[2] Go語言之父 Rob Pike 的親自確認: https://bsky.app/profile/robpike.io/post/3lokt3qzvos2h

[3] 限制字符串長度: https://adam-p.ca/blog/2025/04/string-length/

[4] Strings, bytes, runes, and characters in Go: https://go.dev/blog/strings

[5] 這在其 GitHub issue 中由 Miguel de Icaza 提及: https://github.com/dotnet/runtime/issues/23578

[6] Rune by Connor Taffe: https://connor.zip/posts/2025-05-03-rune

責任編輯:武曉燕 來源: TonyBai
相關推薦

2016-12-13 10:13:18

PHPUTF-8實踐

2020-09-21 08:56:00

GolangUnicode編碼

2022-10-24 09:57:02

runeGo語言

2021-07-13 06:44:04

Go語言數組

2011-03-07 12:31:54

Filezilla

2024-04-07 11:33:02

Go逃逸分析

2021-07-15 23:18:48

Go語言并發

2023-12-21 07:09:32

Go語言任務

2021-06-08 07:45:44

Go語言優化

2023-07-29 15:03:29

2022-07-19 12:25:29

Go

2023-11-30 08:09:02

Go語言

2009-12-17 11:45:38

Linux UTF-8

2014-09-09 14:47:20

2011-08-25 09:43:51

UTF-8中文man

2018-11-02 16:16:41

程序硬盤存儲

2024-03-26 11:54:35

編程抽象代碼

2021-05-12 07:43:02

LinuxUnicodeUTF-8

2025-02-06 16:48:01

2023-12-30 18:35:37

Go識別應用程序
點贊
收藏

51CTO技術棧公眾號

精品无码久久久久国产| 日韩精品免费在线观看| 毛片av在线播放| 人妻丰满熟妇av无码区hd| 亚洲欧美视频| 色av吧综合网| 中文字幕在线播放一区| 国产精品字幕| 亚洲综合色噜噜狠狠| 狼狼综合久久久久综合网| 伊人久久国产精品| 在线日韩欧美| 日韩在线免费视频观看| 亚洲av成人精品一区二区三区| av日韩亚洲| 亚洲久草在线视频| 欧美一区二区三区在线免费观看| 99在线无码精品入口| 国产欧美亚洲一区| 另类色图亚洲色图| 午夜精产品一区二区在线观看的| 免费观看亚洲视频大全| 日本韩国欧美在线| 男人添女荫道口女人有什么感觉| 大乳在线免费观看| 成人av动漫在线| 国产在线视频欧美| 秋霞av一区二区三区| 国内久久精品| 久久香蕉国产线看观看av| 精品无码人妻一区| aaa国产精品视频| 91精选在线观看| 黄在线观看网站| av资源新版天堂在线| 亚洲女性喷水在线观看一区| 日韩欧美99| 亚洲色图另类小说| 成人少妇影院yyyy| av成人综合网| 国产三级三级在线观看| 美女mm1313爽爽久久久蜜臀| 日本一区二区不卡| 日韩av黄色片| 精品91在线| 欧美激情亚洲视频| 精品视频一区二区在线观看| 亚洲精品a级片| 久久精品最新地址| 美女视频久久久| 国产精品99久久精品| 最近中文字幕2019免费| 免费看91的网站| 国产一区二区三区91| 亚洲欧美999| 国产精品毛片一区二区| 欧美人与拘性视交免费看| 精品一区精品二区| 少妇按摩一区二区三区| 欧美日本成人| 日韩中文字幕精品视频| 国产一区二区三区视频播放| 久久亚洲成人| 久久九九全国免费精品观看| 日韩精品123区| 欧美一区二区三区免费看| 久久久国产在线视频| 国产黄在线免费观看| 亚洲啊v在线观看| 九九热这里只有精品6| 九九精品在线观看视频| 亚洲大胆在线| 欧美在线视频一区| 自拍偷拍福利视频| 激情丁香综合五月| 国产不卡一区二区在线观看| 婷婷在线免费观看| 久久久国产午夜精品| 午夜视频久久久| 国产精品久久麻豆| 香蕉久久一区二区不卡无毒影院 | 岛国av免费观看| 加勒比久久高清| 亚洲欧洲日本专区| 国产一区第一页| 伊人久久亚洲热| 国产精品91一区| 国产一区二区视频免费观看| 国产69精品久久久久777| 久久av免费观看| 免费a在线看| 亚洲一区二区三区四区五区黄 | 青青操视频在线播放| 亚洲久久一区| 国产精品视频久久久| 精品欧美一区二区精品少妇| 久久综合色一综合色88| 一本一道久久久a久久久精品91| 18+激情视频在线| 欧美性xxxx在线播放| 中文字幕66页| 欧美丝袜美腿| 久久亚洲影音av资源网| 99热国产在线观看| 久久草av在线| 久久国产精品一区二区三区| 日本成人网址| 欧美日韩国产精品一区二区三区四区 | 尤物网在线观看| 午夜精品一区二区三区三上悠亚| 91国产精品视频在线观看| 日韩精品一区二区三区中文在线| 亚洲精品一区中文字幕乱码| 久久免费看少妇高潮v片特黄| 国产精品五区| av一区观看| 日本在线视频站| 高跟丝袜欧美一区| 中文字幕乱妇无码av在线| 激情五月综合网| 性欧美办公室18xxxxhd| 国产伦精品一区二区三区免.费| 91丨九色丨蝌蚪丨老版| 国产又粗又长又爽视频| 草民电影神马电影一区二区| 日韩精品久久久久| 九九热国产在线| 狠狠久久亚洲欧美| 日韩中文不卡| 国模冰冰炮一区二区| 亚洲二区中文字幕| 欧美激情国产精品免费| 久久er精品视频| 日韩欧美在线观看强乱免费| 日韩激情电影| 亚洲国产私拍精品国模在线观看| 麻豆一区产品精品蜜桃的特点 | 色婷婷国产精品久久包臀| 韩国一区二区三区四区| 一区二区三区网站| 成人网中文字幕| 亚洲精品承认| 欧美日韩一区二区在线观看| aaaaa级少妇高潮大片免费看| 亚洲国产裸拍裸体视频在线观看乱了中文 | 亚洲欧美日韩精品久久| 在线观看国产亚洲| 9久草视频在线视频精品| 性一交一乱一伧国产女士spa| 人人九九精品视频| 欧美理论电影在线观看| aaa国产视频| 亚洲黄色性网站| 国产探花一区二区三区| 欧美精品二区| 成人毛片网站| 成人免费一区二区三区牛牛| 精品国内二区三区| 日本一区二区三区免费视频| 99re成人精品视频| 国产乱子夫妻xx黑人xyx真爽| 一道在线中文一区二区三区| 日韩av大片免费看| 成人av毛片| 91麻豆精品国产91久久久更新时间| 欧美性x x x| 成人一道本在线| 国产午夜伦鲁鲁| 国产免费久久| 国产欧美在线播放| 亚洲精品一线| 亚洲成人久久久久| 韩国av中文字幕| 欧美国产激情二区三区| 久久久久xxxx| 亚洲性人人天天夜夜摸| 欧美日韩三区四区| 福利精品一区| 欧美大片在线看| 十八禁一区二区三区| 丰满岳妇乱一区二区三区| 免费看91的网站| 国产一区二区三区免费播放| 丁香六月激情网| 精品精品久久| 91精品国产一区二区三区动漫| 超级白嫩亚洲国产第一| 国产一区二区三区在线看| 91亚洲国产成人精品一区| 亚洲在线成人精品| 无码 人妻 在线 视频| 国产一区福利在线| 国产精品网站免费| 日韩精品免费| 国产欧美日韩综合一区在线观看| 亚洲va中文在线播放免费| 久久艳片www.17c.com| 香蕉视频国产在线| 欧美精品久久99| 日韩欧美一区二区一幕| 国产精品热久久久久夜色精品三区| 色哟哟网站在线观看| 久久综合图片| 黄色一级片国产| 日产精品一区二区| 韩国成人一区| 国产一区二区在线观| 国产成人精品一区| 国产区美女在线| 日韩中文字幕精品| 日中文字幕在线| 精品日韩在线一区| 96日本xxxxxⅹxxx17| 精品久久久久久久久久久久久久| 欧洲美女女同性互添| 久久夜色精品一区| 黄色性视频网站| 国产一区福利在线| av免费一区二区| 玖玖在线精品| 丁香花在线影院观看在线播放 | 九九九九免费视频| 亚洲有吗中文字幕| 亚洲精品日韩在线观看| 伊人春色之综合网| 国产一区二区三区四区五区在线| av日韩在线免费观看| 国产精品你懂得| 久久人体大尺度| 国模私拍一区二区三区| 99在线视频观看| 久久视频在线播放| 香蕉视频在线免费看| 亚洲欧美国产一本综合首页| 蜜臀久久99精品久久久| 日韩视频不卡中文| 国产黄色片av| 日韩欧美成人一区二区| 国产日韩欧美视频在线观看| 欧美日韩三级在线| 美女黄页在线观看| 欧美无人高清视频在线观看| 成年人视频免费| 色激情天天射综合网| 手机看片久久久| 色噜噜狠狠成人网p站| 五月天婷婷激情| 色婷婷一区二区三区四区| 在线免费黄色av| 色中色一区二区| 亚洲国产成人精品女人久久| 91黄色在线观看| 最新中文字幕第一页| 欧洲生活片亚洲生活在线观看| 天堂网视频在线| 色狠狠桃花综合| 成人黄色免费网| 欧美精品亚洲二区| jlzzjlzzjlzz亚洲人| 日韩欧美国产1| 蜜桃视频久久一区免费观看入口| 亚洲成人黄色网址| 国产激情欧美| 国产精品男人的天堂| 久久av影院| 91色p视频在线| 久久九九精品视频| 国产精品一区二区免费看| 黄色欧美网站| 免费电影一区| 日韩视频在线观看| 成人在线观看毛片| 影音先锋亚洲精品| 日韩人妻精品无码一区二区三区| 日韩精品亚洲一区二区三区免费| 黄色永久免费网站| 国产一区二区伦理| 少妇被狂c下部羞羞漫画| 久久久久久久久蜜桃| 天美传媒免费在线观看| 一区二区久久久| 国产精品21p| 日韩一区二区在线观看视频| 天天干,夜夜操| 视频一区视频二区国产精品 | 欧美乱做爰xxxⅹ久久久| 精品电影一区| 久久久精品麻豆| 国产成人午夜高潮毛片| 蜜桃传媒一区二区亚洲av| 国产精品久久一卡二卡| 国产一级aa大片毛片| 色婷婷久久久久swag精品| 国内精品一区二区三区| 国产三级视频在线| 欧美精品一区三区| 日本成人三级电影| 亚洲一区二区久久久久久久| 西野翔中文久久精品国产| 亚洲天堂电影网| 亚洲黄色av| 午夜免费看毛片| 91色视频在线| 中文字幕影音先锋| 91福利视频久久久久| 亚洲第一天堂在线观看| 中文字幕亚洲欧美日韩高清| 国产丝袜在线观看视频| 国产免费一区二区三区在线观看| 久久97久久97精品免视看秋霞| 亚洲国产欧洲综合997久久| 尹人成人综合网| 色婷婷一区二区三区在线观看| 91日韩精品一区| 欧美极品aaaaabbbbb| 欧美日韩国产大片| 每日更新av在线播放| 欧美激情xxxxx| 99er精品视频| 天堂资源在线亚洲资源| 99在线精品视频在线观看| 韩国三级hd中文字幕有哪些| 欧美国产一区在线| 成人在线免费看视频| 欧美成人一区二区三区| 日本中文字幕电影在线免费观看| 日韩美女免费视频| 国产欧美自拍一区| 中文字幕日韩精品无码内射| 国产资源精品在线观看| 人与嘼交av免费| 日韩欧美精品中文字幕| 欧美一区二区三区黄片| 欧美精品video| 亚洲天堂中文字幕在线观看| 黄色一级片网址| 国产综合色视频| 免费国产羞羞网站美图| 日韩一区二区在线看| 麻豆系列在线观看| 国产日韩欧美电影在线观看| 超碰成人久久| 男女无套免费视频网站动漫| 亚洲国产精品成人综合| 久久精品偷拍视频| 国产亚洲欧美另类中文| 搜成人激情视频| 日韩欧美亚洲精品| 日本一区中文字幕| 婷婷综合在线视频| 欧美精品在线观看播放| 成人免费网址| 超碰97网站| 夜夜嗨一区二区| 麻豆av免费观看| 欧美吻胸吃奶大尺度电影 | 日韩精品每日更新| 少妇一级淫免费播放| 国产精品午夜在线| 中文字幕在线2019| 久久精彩免费视频| 一区二区亚洲视频| 精品这里只有精品| 国产夜色精品一区二区av| 免费黄色一级大片| 久久久国产精彩视频美女艺术照福利| 亚洲一区有码| 99在线观看视频免费| 91视视频在线观看入口直接观看www| 国产综合精品视频| 尤物yw午夜国产精品视频明星| 欧美黑粗硬大| 成人短视频在线观看免费| 99久久免费精品高清特色大片| 特级毛片www| 日日狠狠久久偷偷四色综合免费| 国产成人免费av一区二区午夜| 久久精品在线免费视频| 成年人午夜久久久| 超碰在线免费97| 久久97久久97精品免视看| 米奇精品关键词| 欧美精品成人网| 18欧美乱大交hd1984| 黄色片一区二区三区| 国产精品久久999| 国产精品v亚洲精品v日韩精品| 麻豆国产精品一区| 欧美日本一区二区| 成av人片在线观看www| 亚洲精品成人自拍| 成人在线视频首页| 中文字幕激情视频| 久久久亚洲国产天美传媒修理工| 加勒比久久综合| 国产精品熟妇一区二区三区四区 | 国产aaa一级片| 亚洲免费毛片网站| 国产一级免费在线观看| 99久re热视频这里只有精品6|