""中文編程"知乎專欄原文" 看到 "國人創造中文編程語言的優勢" 一文的評論後, 此文基於個人視野, 從幾個方面闡述中文編程興起的必然性和展望. 下麵是一些近十幾年中的相關趨勢. 對代碼可讀性的重視將會從大公司向小公司逐漸普及 在這個2010年的 "Quara回答" 中, Google已經把可讀性 ...
看到國人創造中文編程語言的優勢一文的評論後, 此文基於個人視野, 從幾個方面闡述中文編程興起的必然性和展望. 下麵是一些近十幾年中的相關趨勢.
對代碼可讀性的重視將會從大公司向小公司逐漸普及
在這個2010年的Quara回答中, Google已經把可讀性審核作為代碼審核的一部分包括在了標準軟體開發過程中, 就算國內遲十年開始, 相信不少國內大公司已經開始進行了或多或少的可讀性審核, 而且已經意識到了英文水平和對單詞理解偏差造成的額外開發維護成本, 只是暫時沒有找到更合適和成熟的開發途徑而已. 這個需求只會隨著國內團隊開發的日益成熟和項目生命期的變長而越來越大.
開源軟體/思想的推廣
多數現有的中文編程語言/工具都是閉源的. 而趨勢是新語言從成型就開源. 國人已經有不少這樣的嘗試, 雖然絕大多數是英文編程語言, 但也有開源的中文編程語言了(國人創造中文編程語言的優勢最後列表). 隨著更多的開發者參與到中文編程語言設計的開源項目中, 誕生現象級的中文語法的編程語言只是時間問題, 個人的猜想是5-10年(2017-11-23).
新一代計算技術的興起
在量子計算領域, 中國幾乎和國外處於一個起跑線. 商用雖有距離, 但相信我們這一代就可以看到. 雖然現在它的編程語言還很底層(以量子門外漢的眼光, 現在是類似於電子電腦的彙編語言時期), 但也可以開始考慮中文編程語言的設計了. 歡迎專業人士一同探討: 為量子計算設計的中文編程語言 · Issue #29 · program-in-chinese/overview
自然語言處理在軟體開發/代碼分析中的應用
這是個尚在搖籃的領域, 但必定會隨著編程語言/軟體工程的演進和自然語言處理的熱度而進一步發展. 比如論文: Investigating the Use of Code Analysis and NLP to Promote a Consistent Usage of Identifiers. 在這個背景下, 使用中文進行編程就有了更大的意義. 它不僅能從中文自然語言處理技術受益, 而且可以提供代碼領域的獨特的中文語料庫(這個語料庫現在基本是英文的)而反哺中文NLP技術的發展.
Unicode的普及
各種表現包括: Unicode在2004年之後在web的加速普及, Google Java代碼風格將源碼格式定為UTF8等等. 這些都更利於中文命名在源碼中的實踐和普及.
下麵是更一般和不隨時間改變的:
英文學習的門檻再低, 也是第二語言
除非身處全英文環境, 母語是中文的少兒不可能對英文有更高的敏感度. 在可預見的將來, 中國絕大多數人還是會處於中文環境中. 更何況, 現在英文學習熱潮本身就是很大程度被IT熱(矽谷)催生的. 隨著中國國力和科技水平逐漸和國外平齊, 這個熱度從長遠看只會下降.
青出於藍
正如四大發明始於中國而盛於西方, 電腦系統雖然始於西方, 不意味著再發明和創造不可能發生在其他地方. 中國在系統領域(超算等等)的彎道超車就是個例子. 而軟體領域的門檻其實更低. 中國占1/5的世界人口, 和越來越多希望學習中國文化的外國人, 就是中文編程最好的土壤.
小結
無論天時地利人和, 都越來越有利於中文編程的創造和推廣.
姊妹篇: 中文編程興起的可能途徑