java語(yǔ)言的演化——讀JavaOne ppt筆記
Posted on 2008-06-18 00:20 dennis 閱讀(2061) 評(píng)論(0) 編輯 收藏 所屬分類: java 、涂鴉
1、應(yīng)用VS.語(yǔ)言 應(yīng)用是特性越多越好,應(yīng)用是rich的;而語(yǔ)言是pure的,更少的、普通的特性更好。 2、添加一個(gè)java語(yǔ)言特性的三個(gè)前提:尊重過去、著眼未來以及顧及模型。 無論是增加、減少或者改變一個(gè)feature都可能broken已經(jīng)存在的代碼,一個(gè)新增加的feature必須兼容已經(jīng)存在的代碼,兼容是個(gè)沉重的包袱,就java語(yǔ)言而言,我相當(dāng)認(rèn)同尊重過去這一點(diǎn),哪怕加入閉包這樣的特性也不應(yīng)當(dāng)以損壞兼容性為代價(jià),更好的選擇是將這些特性讓jvm上的新語(yǔ)言去實(shí)現(xiàn)(比如JRuby、Scala),java語(yǔ)言作為成熟的工業(yè)語(yǔ)言本身不應(yīng)當(dāng)做太大的改變。而著眼未來,也就是說新的語(yǔ)言特性應(yīng)該為未來的語(yǔ)法擴(kuò)展留有空間,它的語(yǔ)法/語(yǔ)義不應(yīng)當(dāng)跟現(xiàn)存的或者潛在的特性相沖突,以便可以持續(xù)地演化。再談?lì)櫦爱?dāng)前的模型,一門語(yǔ)言代表著一種計(jì)算模型,比如simula是OO模型(classes),Erlang就是inter-process
communication的模型(actor)。Java語(yǔ)言也有一個(gè)簡(jiǎn)單的模型:首先它是“高層”語(yǔ)言,是一門通用、并發(fā)、基于類的OO語(yǔ)言,其次,它跟API、JVM有良好的結(jié)合。Java語(yǔ)言模型有四個(gè)原則: a)鼓勵(lì)high-level實(shí)踐,通過抽象來隱藏偶然復(fù)雜度。簡(jiǎn)而言之:do
the right thing。 b)追求清晰,程序被讀的時(shí)候遠(yuǎn)遠(yuǎn)多于寫。簡(jiǎn)而言之:do
the thing right. c)青睞靜態(tài)類型,靜態(tài)類型能增進(jìn)對(duì)代碼的信心,靜態(tài)類型能證明bug在編譯時(shí)的不存在,而測(cè)試和動(dòng)態(tài)類型能證明bug的存在。我的觀點(diǎn)是,大多數(shù)難以尋找和解決的bug都是runtime的,靜態(tài)類型在此方面能給出的幫助有限,充分并且適宜的測(cè)試更加能增強(qiáng)你對(duì)應(yīng)用的信心。 d)語(yǔ)言比之API的更廣泛。one
language,many
api。API來去匆匆,而語(yǔ)言卻是forever,因而將語(yǔ)言和API分離是明智的,一些特性可以做為庫(kù)來實(shí)現(xiàn),jdk5并發(fā)庫(kù)的引入就很好,jdk7在并發(fā)方面同樣將引入fork/join模型。 java語(yǔ)言的演化也當(dāng)遵循這四個(gè)原則。再看看傳說中的閉包語(yǔ)言,當(dāng)它跟泛型結(jié)合的時(shí)候?qū)懗鰜淼臇|西還談得上清晰嗎?閉包的實(shí)現(xiàn)能否解決兼容性問題也是個(gè)疑問。就四個(gè)提案,C3S需要引入method關(guān)鍵字(類似lambda),F(xiàn)CM的#號(hào)看起來比較怪異,在我看來,CICE和BGGA更符合胃口,CICE對(duì)java語(yǔ)言的變動(dòng)應(yīng)該最小,學(xué)習(xí)曲線也比較平緩,BGGA的=>符號(hào)更有函數(shù)式語(yǔ)言的味道。閉包的引入,某種程度上能減少敲擊鍵盤的次數(shù)并實(shí)現(xiàn)一些高階功能,特別是在聚合操作(如filter、map等)和單抽象方法類(如Runnable,Callable)的使用上,但是在現(xiàn)代IDE的自動(dòng)化幫助下,這個(gè)帶來的價(jià)值是值的懷疑的。