溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Java老矣 尚能飯否?

發(fā)布時間:2020-09-25 09:40:07 來源:腳本之家 閱讀:130 作者:張建鋒 欄目:編程語言

22 歲,對于一個技術(shù)人來說可謂正當(dāng)壯年。但對于一門編程語言來說,情況可能又有不同。各類編程語言橫空出世,紛戰(zhàn)不休,然而 TIOBE 的語言排行榜上,Java 卻露出了明顯的頹勢。這個老牌的語言,未來會是怎樣?

Java老矣 尚能飯否?

  寫在前面

  從 1995 年第一個版本發(fā)布到現(xiàn)在,Java 語言已經(jīng)在跌宕起伏中走過了 22 年,最新的 Java 版本也已經(jīng)迭代到 Java 9。當(dāng)年 Java 語言的跨平臺優(yōu)勢如今看來也只不過是家常小菜,Go、Rust 等語言橫空出世,進一步拓寬了編程語言的邊界。當(dāng)年發(fā)明 Java 語言的 Sun 公司早已被 Oracle 收購,Oracle 現(xiàn)在也正處于水深火熱的云計算浪潮當(dāng)中,甚至連 Java 之父 James Gosling 也加入了當(dāng)今世界最大的云計算公司 AWS。

  Java 語言發(fā)展的這 20 年也正是全球互聯(lián)網(wǎng)迅猛發(fā)展的 20 年,Java 語言同時也見證了電商浪潮、移動互聯(lián)網(wǎng)浪潮、大數(shù)據(jù)浪潮、云計算浪潮,所以在現(xiàn)今各大互聯(lián)網(wǎng)公司身上都能看到 Java 的身影。

  縱看 Java 語言的發(fā)展,不禁讓人聯(lián)想到辛棄疾的一首詞:

  千古江山,英雄無覓,孫仲謀處。舞榭歌臺,風(fēng)流總被雨打風(fēng)吹去。斜陽草樹,尋常巷陌,人道寄奴曾住。想當(dāng)年,金戈鐵馬,氣吞萬里如虎。元嘉草草,封狼居胥,贏得倉皇北顧。四十三年,望中猶記,烽火揚州路??煽盎厥祝鹭傡粝?,一片神雅社鼓。憑誰問,廉頗老矣,尚能飯否?

  TIOBE 的語言排行榜顯示,自 2016 年初 Java 語言就出現(xiàn)了明顯的下頹趨勢,開發(fā)者社區(qū)也出現(xiàn)了一些唱衰 Java 語言的論調(diào),編者心中也有些許疑問:Java 老矣,尚能『飯』否?基于這樣的背景,InfoQ 邀請到了 Java 資深專家張建鋒來為大家解讀 Java 語言的發(fā)展現(xiàn)狀以及未來。

  Java 語言的發(fā)展回顧

  Java 語言源于 1991 年 Sun 公司 James Gosling 領(lǐng)導(dǎo)的的 Ork 項目,1995 年 Sun 公司正式起名為 Java,并提出“Write once, Run anywhere"的口號。

  1996 年 1 月 Java 1.0 發(fā)布,提供了一個解釋執(zhí)行的 Java 虛擬機,其時恰逢互聯(lián)網(wǎng)開始興起,Java 的 Applet 能在 Mozilla 瀏覽器中運行,被看作是未來的互聯(lián)網(wǎng)語言。

  1997 年 2 月 Java 1.1 發(fā)布,Java 語言的基本形態(tài)基本確定了,比如反射 (reflection), JavaBean, 接口和類的關(guān)系等等,一直到今天都保持一致。然而,Java 最初的一些目標(biāo),如在瀏覽器中執(zhí)行 Applet,以及跨平臺的圖形界面 Awt 很快遭遇到負面的評價。

  1998 年 12 月,Java 第一個里程碑式的版本,即 Java 1.2 發(fā)布了。這個版本使用了 JIT(Just in time)編譯器技術(shù),使得語言的可遷移性和執(zhí)行效率達到最優(yōu)的平衡,同時 Collections 集合類設(shè)計優(yōu)良,在企業(yè)應(yīng)用開發(fā)中迅速得到了廣泛使用。Sun 公司把 Java 技術(shù)體系分成三個方向,分別是 J2SE(面向桌面和通用應(yīng)用開發(fā)),J2EE(面向企業(yè)級應(yīng)用開發(fā)),J2ME(面向移動終端開發(fā))。這個分類影響非常久遠,體現(xiàn)出主流語言設(shè)計者的思想:針對于不同的應(yīng)用領(lǐng)域,在形態(tài),API 集合等進行劃分。

  2000 年 5 月,Java 1.3 發(fā)布,這個版本中 Corba 作為語言級別的分布式對象技術(shù),成為 J2EE 的一個技術(shù)前提。J2EE 受到 Corba 的設(shè)計的影響較大,早期 EJB 的 Home,接口和實現(xiàn)就是 Corba 在 C 語言的實現(xiàn),被移植到 Java 語言之中。J2EE 中的 Servlet 規(guī)范獲得了極大的成功,伴隨著互聯(lián)網(wǎng)的興起,和瀏覽器直接通過 HTTP 協(xié)議交互的 Servlet,和眾多的 MVC 框架,成為 Web1.0 的網(wǎng)紅。

  2002 年 2 月,Java 1.4 發(fā)布,Java 語言真正走向成熟,提供了非常完備的語言特性,如 NIO,正則表達式,XML 處理器等。同年微軟的 .NET 框架發(fā)布,兩者開始了為期十幾年的暗自競爭。從語言特性上來說,.NET 后發(fā)先至,一直處于優(yōu)勢。但 Java 依賴良好的開發(fā)者生態(tài),絕大多數(shù)大型軟件公司的使用者眾多和不斷貢獻,以及對 Linux 操作系統(tǒng)良好的支持,漸漸的在服務(wù)器端獲得優(yōu)勢地位。

  2004 年 9 月,Java 5 發(fā)布,Sun 不再采用 J2SE, J2EE 這種命名方式,而使用 Java SE 5, Java EE 5 這樣的名稱。我認為 Java 5 是第二個里程碑式的版本。Java 語言語法發(fā)生很大的變化,如注解 (Annotation),裝箱 (Autoboxing),泛型 (Generic),枚舉 (Enum),foreach 等被加入,提供了 java.util.concurrent 并發(fā)包。Java 5 對于 Java 語言的推動是巨大的,特別是注解的加入,使得語言定義靈活了很多,程序員可以寫出更加符合領(lǐng)域定義的描述性程序。

  2006 年 5 月, JavaEE 5 發(fā)布,其中最主要是 EJB3.0 的版本升級。在此之前,EJB2.X 版本被廣泛質(zhì)疑,SpringFramework 創(chuàng)建者 Rod Johnson 在經(jīng)典書籍“J2EE Development without EJB“中,對 EJB2 代表的分布式對象的設(shè)計方法予以批駁。EJB3 則重新經(jīng)過改造,使用注解方式,經(jīng)過應(yīng)用服務(wù)器對 POJO 對象進行增強來實現(xiàn)分布式服務(wù)能力。在某種程度,可以說 EJB3 挽救了 JavaEE 的過早消亡。

  2006 年 12 月,Java 6 發(fā)布,這個語言語法改進不多,但在虛擬機內(nèi)部做了大量的改進,成為一個相當(dāng)成熟穩(wěn)定的版本,時至今日國內(nèi)的很多公司依然以 Java6 作為主要 Java 開發(fā)版本來使用。同年 Sun 公司做出一個偉大的決定,將 Java 開源。OpenJDK 從 Sun JDK 1.7 版本分支出去,成為今天 OpenJDK 的基礎(chǔ)。OpenJDK6 則由 OpenJDK7 裁剪而來,目前由紅帽負責(zé)維護,來滿足 Redhat Enterprise Linux 6.X 用戶的需要。

  2009 年 12 月,JavaEE 6 發(fā)布,這個版本應(yīng)該說是 JavaEE 到目前為止改進最大影響最深遠的一個版本。因為 JavaEE5 只有 EJB3 適應(yīng)了 Java 注解語法的加入,而 EE6 全面接納了注解。CDI 和 BeanValidation 規(guī)范的加入,在 POJO 之上可以定義完備的語義,由容器來決定如何去做。Servlet 也升級到 3.0 版本,并在接口上加入異步支持,使得系統(tǒng)整體效率可以大幅提高。EE 劃分為 Full Profile 和 Web Profile,用戶可以根據(jù)自己的需要選擇不同的功能集。

  在此之前,Oracle 已經(jīng)以 74 億美金的價格收購了 Sun 公司,獲得了 Java 商標(biāo)和 Java 主導(dǎo)權(quán)。也收購了 BEA 公司,獲得市場份額最大的應(yīng)用服務(wù)器 Webogic。JavaEE 6 雖然是收購之后發(fā)布的版本,但主要的設(shè)計工作仍然由原 Sun 公司的 Java 專家完成。

  2011 年 7 月,Oracle 發(fā)布 Java 7, 其中主要的特性是 NIO2 和 Fork/Join 并發(fā)包,盡管語言上沒有大的增強,但我個人認為,自從 Oracle JDK(包括 OpenJDK7),Java 虛擬機的穩(wěn)定性真正做到的工業(yè)級,成為一個計算平臺而服務(wù)于全世界。

  2013 年 6 月,Oracle 發(fā)布 JavaEE 7,這個版本加入了 Websocket,Batch 的支持,并且引入 Concurrency 來對服務(wù)器多線程進行管控。然而所有的子規(guī)范,算上可選項 (Optional) 總共有 40 多項,開發(fā)者光是閱讀規(guī)范文本就很吃力了,更不要說能夠全局精通掌握。JavaEE 規(guī)范的本質(zhì)是企業(yè)級應(yīng)用設(shè)計的經(jīng)驗?zāi)Y(jié),每一個 API 都經(jīng)過眾多豐富經(jīng)驗的專家反復(fù)商議并確定。各個版本之間可以做到向后兼容,也就是說,即使是 10 年前寫的 Servlet 程序,當(dāng)前的開發(fā)者也可以流暢的閱讀源碼,經(jīng)過部分代碼調(diào)整和配置修改,可以部署在當(dāng)今的應(yīng)用服務(wù)器上。反過來,今后用 Servlet4 寫的程序,瀏覽器和服務(wù)器通信使用全新的 HTTP/2 協(xié)議,但程序員在理解上不會有障礙,就是因為 Servlet 規(guī)范的 API 非常穩(wěn)定,基本沒有大的變化修改。

  2014 年 3 月,Oracle 發(fā)布 Java 8,這個版本是我認為的第三個有里程碑意義的 Java 版本。其中最引人注目的便是 Lambda 表達式了,從此 Java 語言原生提供了函數(shù)式編程能力。語言方面大的特性增加還有:Streams,Date/Time API, 新的 Javascript 引擎 Nashorn,集合的并行計算支持等,Java8 更加適應(yīng)海量云計算的需要。

  按照原來的計劃,Java9 應(yīng)該在今年 7 月發(fā)布,但因為模塊化 (JPMS) 投票未通過的原因,推遲到今年 9 月份發(fā)布。

  JavaEE 8 也會在今年發(fā)布,預(yù)計的時間在 8-10 月。其中最主要更新是 Servlet 4.0 和 CDI 2.0,后者已經(jīng)完成最終規(guī)范的發(fā)布和投票。

  Java 社區(qū)情況介紹

  我們按照兩個方面介紹 Java 社區(qū)情況。

  Java User Group (JUG,Java 用戶組) 目前全世界范圍有 100 多個 JUG 組織,分布在各個大洲各個國家,一般來說以地域命名。目前最有影響力的兩個 JUG 分別是倫敦的 LJC (London Java Community) 和巴西的 SouJava,目前都是 JCP 的 EC (執(zhí)行委員會) 成員。國內(nèi)目前有 GreenTea JUG (北京和杭州),Shanghai JUG,GuangDong JUG, Shenzhen JUG, Nanjing JUG 等。GreanTeaJUG 以阿里巴巴研發(fā)部門成員為核心,包括北京和杭州兩地各個公司從事 Java 開發(fā)的研發(fā)人員,過去幾年成功舉辦了很多有業(yè)界影響力的活動,特別是邀請到眾多國外的 Java 技術(shù)專家來分享知識,目前是國內(nèi)最大的 JUG 開發(fā)者組織。

  Java 開源社區(qū) Java 是一門開放的語言,其開源社區(qū)也是參與者眾多。最有名的應(yīng)當(dāng)數(shù) Apache 社區(qū),目前已經(jīng)擁有近 200 個頂級項目,其中絕大多數(shù)是 Java 語言項目。在 Java 生態(tài)圈中,具有重要地位的如 Ant、Commons、Tomcat、Xerces、Maven、 Struts、Lucene、ActiveMQ、CXF、Camel、Hadoop 等等。很多技術(shù)時代,一大批 Java 項目加入,如 Web 時代的 Velocity、Wicket;JavaEE 相關(guān)的 Tomee、OpenJPA、OpenWebBeans、Myfaces;WebService 時代的 jUDDI、Axis、ServiceMix;Osgi 時期的 Flex、Karaf;大數(shù)據(jù)時代的 HBase、Hive、ZooKeeper、Cassandra;云時代的 Mesos、CloudStack 等等。

  涉及到軟件開發(fā)的方方面面,可以說當(dāng)今幾乎所有的中型以上 Java 應(yīng)用中,都會有 Apache 開源項目的身影。國內(nèi)最早參與 Apache 社區(qū)的以國外軟件公司國內(nèi)研發(fā)團隊成員為主,如紅帽、IONA、Intel、IBM 研發(fā)中心等。如今國內(nèi)互聯(lián)網(wǎng)公司和軟件公司也不斷的參與,特別是開始主導(dǎo)一些 Apache 項目,如 Kylin 等。

  JBoss 開源社區(qū),包含了 50 多個 Java 開源項目,其中有 Hibernate、Drools、jBPM 等業(yè)界知名開源項目,也有 Undertow、Byteman、Narayana 等名氣不算大,但絕對是相應(yīng)領(lǐng)域業(yè)界的頂級優(yōu)秀項目。當(dāng)前 JBoss 開源社區(qū)主要以企業(yè)應(yīng)用中間件軟件為主,RedHat 是主要的技術(shù)貢獻力量。

  Eclipse 開源社區(qū),之前主要是包含 Eclipse IDE 的項目,后來也逐步進行多方面的擴展,比如 OSGi,服務(wù)器等,目前一些知名 Java 項目,如 Jetty、Vertx 等都是 Eclipse 開源組織成員。此外 IOT 目前是 Eclispe 的一個重點方向,在這里可以找到完整的 IOT Java 開發(fā)方案。

  Spring 開源社區(qū),以 SpringFramework 為核心,包括 SpringBoot、SpringCloud、SpringSecurity、SpringXD 等開源項目,在國內(nèi)有廣泛的應(yīng)用場景。

  目前大的玩家

  Java 語言和品牌都是 Oracle 公司所有,所以 Oracle 公司是 Java 最主要的廠商。絕大多數(shù) JSR (Java 規(guī)范提案) 的領(lǐng)導(dǎo)者都是 Oracle 的雇員。

  Java 是一個龐大的生態(tài)圈,全世界的軟件和互聯(lián)網(wǎng)公司絕大多數(shù)都是 Java 用戶,同時也可以參與推動 Java 語言的發(fā)展。任何組織或者個人都可以加入 JCP(Java Community Process),并提交 JSR 來給 JavaSE,JavaEE,JavaME 等提交新的 API 或者服務(wù)定義。Java 擁有當(dāng)今最完備的語言生態(tài),幾乎所有能想到的應(yīng)用范圍,都有軟件廠商提出過標(biāo)準(zhǔn)化的構(gòu)想,其中很多已經(jīng)被接納為 JSR 提案。如今 JSR 總數(shù)已經(jīng)都 400 多個。

  JCP 是發(fā)展 Java 的國際組織,其中的執(zhí)行委員會(EC)以投票的形式對 JSR 提案進行表決。目前 EC 包括 16 個合約 (Ratified) 席位,6 個選舉 (Elected) 席位和 2 個合伙 (Associate) 席位,以及 Oracle 作為所有者的永久席位。非永久席位每兩年重新選舉一次,每次選舉為 24 個席位的一半,即為 12 個。

  當(dāng)前 EC 委員會中,對于 Java 起到最重要作用的,無疑是 Oracle,IBM 和 Redhat 三家公司。Oracle 自然不用說;Redhat 領(lǐng)導(dǎo)著 JavaEE8 中兩項 JSR,并且在操作系統(tǒng),Linux,虛擬化,云計算等基礎(chǔ)軟件方面是產(chǎn)品領(lǐng)導(dǎo)者;IBM 是軟硬件最大的廠商,擁有自己的 Unix 操作系統(tǒng)和 JDK 版本。這三家軟件廠商也是中間件廠商的強者,它們對于 Java 的影響是至關(guān)重要的。前不久投票被否決的 JSR 376(JPMS) 模塊化提案,就是 Redhat 和 IBM 先后表示要投反對票,最后才沒有通過的。

  另外的幾個重要的 Java 參與方分別包括:巨型互聯(lián)網(wǎng)公司,以 Twitter 為代表;大型金融公司,以高盛,瑞信為代表;強大的硬件產(chǎn)商,Intel,NXP,Gemalto 等;大型系統(tǒng)方案廠商,HP, Fijitsu;當(dāng)然還有掌握先進 Java 技術(shù)的公司,如 Azul,Hazelcast,Tomitribe,Jetrains 等等。這些公司共同對 Java 的發(fā)展起到關(guān)鍵作用。

  GC 方面的進展

  JDK 中主要的 GC 分類有:

Serial,單線程進行 GC,在它進行垃圾收集時,必須暫停其他所有的工作線程,直到它收集結(jié)束。

Parallel,相比 Serial 收集器,Parallel 最主要的優(yōu)勢在于使用多線程去完成垃圾清理工作,這樣可以充分利用多核的特性,大幅降低 GC 時間。

CMS (Concurrent Mark-Sweep),是以犧牲吞吐量為代價來獲得最短回收停頓時間的垃圾回收器。實現(xiàn) GC 線程和應(yīng)用線程并發(fā)工作,不需要暫停所有應(yīng)用線程。

G1(Garbage First Garbage Collector),G 設(shè)計初衷是為了盡量縮短處理超大堆(大于 4GB)時產(chǎn)生的停頓。相對于 CMS 的優(yōu)勢而言是內(nèi)存碎片的產(chǎn)生率大大降低。

  目前在 JDK8 中以上 4 種 GC 都可以使用,而在 JDK9 中 G1 GC 會成為默認的垃圾收集器。

  在 OpenJDK 方面,Redhat 開源并貢獻了 Shenandoah GC。這是一種新的 Java 虛擬機 GC 算法,目標(biāo)是利用現(xiàn)代多核 CPU 的優(yōu)勢,減少大堆內(nèi)存在 GC 處理時產(chǎn)生的停頓時間。在使用大內(nèi)存的應(yīng)用上使用,如>20G 堆空間。Fedora24 以后,官方源中的 OpenJDK 即帶有 Shenandoah 算法,不過 JDK9 中還不會被加入。

  無停頓的高性能 GC 就是 Azul 公司的 C4(Continuously Concurrent Compacting Collector) GC 了,但只提供商業(yè)版本使用。

  另外 IBM J9 中 Balanced GC,表現(xiàn)也很出色,能夠保證相對一致的暫停時間而避免破壞性的長時間停頓。Balanced GC 應(yīng)用在各類 IBM 中間件產(chǎn)品之中。

  Java 9 目前已經(jīng)可以確認的特性介紹

  Java9 中,最受人關(guān)注的新特性就是 Jigsaw 項目帶來的模塊化技術(shù)特性。

  Java 語言一直缺乏語言級別的模塊化能力,目前模塊化技術(shù)通過 OSGi, JBoss Modules 等項目,已經(jīng)在服務(wù)端程序得到了廣泛的應(yīng)用。Java 在語言級別引入模塊化能力,將極大的促進 Java 應(yīng)用程序組件化,模塊化的改變。應(yīng)用程序通過模塊化拆分,可以做到更靈活的引入,加載,移除組件,占用更少的內(nèi)存,更適合云計算時代的要求。在 JDK9 EA(預(yù)覽版)中,原有的 rt.jar 已經(jīng)被劃分為若干了 jmod,通過模塊內(nèi)的 module-info.java 文件來聲明模塊間的引用關(guān)系。

  然而,模塊化改造是個漸進而適度的過程,Java9 為了可兼容 Java8 以前應(yīng)用程序的運行,做出很多的讓步,模塊定義嚴(yán)格性沒有那么苛刻。各個廠商也有對自己現(xiàn)有系統(tǒng)可無縫運行在 Java9 上的商業(yè)訴求。Java 模塊化提案還得花更多的時間去討論和修改。

  Java9 中的 jshell 工具實現(xiàn)了 REPL,即讀取,求值,打印,循環(huán)。這個工具可以使得開發(fā)者交互式的使用 Java,方便于系統(tǒng)管理,調(diào)試,使用??梢韵胂竦接辛?jshell 后,Java 語言更加適合初學(xué)者入門學(xué)習(xí)。

  Jlink 工具和 AOT(預(yù)先編譯技術(shù))。一直以來,Java 運行方式是把程序編譯成 class 文件,然后通過 jvm 運行的。這種工作方式可以做到跨平臺移植,在互聯(lián)網(wǎng)時代初期,各種 Unix 繁榮和 Windows 在桌面的一統(tǒng)局面下,對于占據(jù)市場起到?jīng)Q定性作用。

  然而到了今天,無論是大型互聯(lián)網(wǎng)公司還是企業(yè)內(nèi)部,x86 平臺 64 位服務(wù)器已經(jīng)成為主要的選擇。從運行效率考慮,可以把 java 程序編譯成可執(zhí)行的二進制文件,更加適應(yīng)云計算和容器技術(shù)發(fā)展的需要。

  利用 jlink/jaotc 工具,可以把一個 Java 程序編譯成可執(zhí)行文件,在 Java9 推出時,可能只有 java.base 模塊支持 AOT。

  安全方面的加強。引入新的摘要算法 SHA-3,內(nèi)置 ALPN 使得更好的支持 HTTP/2 協(xié)議,提供 DTLS(數(shù)據(jù)包傳輸層安全性協(xié)議),可以保證 UDP 數(shù)據(jù)傳輸?shù)陌踩?,PKCS12 格式替代原有的 JKS 成為 keystore 的默認格式。

  此外,統(tǒng)一 JVM 日志 (Unified JVM Logging),多版本共存 jar (Multi-release jar files),接口內(nèi)部的私有方法 (Interface provate method) 等也是非常重要的新特性。

  與其他語言的對比,Java 的優(yōu)勢

  Java 是最好的語言么?不是,因為在每個領(lǐng)域都有更合適的編程語言。

  C 語言無疑是現(xiàn)代計算機軟件編程語言的王者,幾乎所有的操作系統(tǒng)都是 C 語言寫成的。C++ 是面向?qū)ο蟮?C 語言,一直在不斷的改進。

  JavaScript 是能運行在瀏覽器中的語言,豐富的前端界面離不開 Javascript 的功勞。近年來的 Node.js 又在后端占有一席之地。Python 用于系統(tǒng)管理,并通過高性能預(yù)編譯的庫,提供 API 來進行科學(xué)計算,文本處理等,是 Linux 必選的解釋性語言。

  Ruby 強于 DSL(領(lǐng)域特定語言),程序員可以定義豐富的語義來充分表達自己的思想。Erlang 就是為分布式計算設(shè)計的,能保證在大規(guī)模并發(fā)訪問的情況下,保持強壯和穩(wěn)定性。Go 語言內(nèi)置了并發(fā)能力,可以編譯成本地代碼。當(dāng)前新的網(wǎng)絡(luò)相關(guān)項目,很大比例是由 Go 語言編寫的,如 Docker、Kubernetes 等。

  編寫網(wǎng)頁用 PHP,函數(shù)式編程有 Lisp,編寫 iOS 程序有 Swift/ObjectiveC。

  一句話概括,能留在排行榜之上的語言,都是好的語言,在其所在的領(lǐng)域能做到最好。

  那么,Java 語言到底有什么優(yōu)勢可以占據(jù)排行榜第一的位置呢?

  其一,語法比較簡單,學(xué)過計算機編程的開發(fā)者都能快速上手。

  其二,在若干了領(lǐng)域都有很強的競爭力,比如服務(wù)端編程,高性能網(wǎng)絡(luò)程序,企業(yè)軟件事務(wù)處理,分布式計算,Android 移動終端應(yīng)用開發(fā)等等。

  最重要的一點是符合工程學(xué)的需求,我們知道現(xiàn)代軟件都是協(xié)同開發(fā),那么代碼可維護性,編譯時檢查,較為高效的運行效率,跨平臺能力,豐富的 IDE,測試,項目管理工具配合。都使得 Java 成為企業(yè)軟件公司的首選,也得到很多互聯(lián)網(wǎng)公司的青睞。

  沒有短板,容易從市場上找到 Java 軟件工程師,軟件公司選擇 Java 作為主要開發(fā)語言,再在特定的領(lǐng)域使用其他語言協(xié)作編程,這樣的組合選擇,肯定是不會有大的問題。

  所以綜合而言,Java 語言全能方面是最好的。

  Java 未來方向的展望

  如今的 Java,已經(jīng)在功能上相當(dāng)豐富了,Java 8 加入 Lambda 特性,Java 9 加入模塊化特性之后,重要的語言特性似乎已經(jīng)都納入進來。如果要說值得考慮的一些功能,我覺得有以下幾點:

  模塊化改造完畢之后,可能會出現(xiàn)更多專業(yè)的 JDK 發(fā)行軟件商,提供在功能方面,比如針對于分布式計算,機器學(xué)習(xí),圖形計算等,納入相關(guān)的功能庫作為文件。這樣專業(yè)行業(yè)客戶可以選擇經(jīng)過充分優(yōu)化后的 JDK 版本。

  Java 語義上對“模式匹配”有更強的支持,如今的 switch 語句能力還是比較欠缺,可以向 Erlang, Scala 等語言借鑒。

  多線程并發(fā)處理,Java 做的已經(jīng)很好了。不過我個人覺得可以在多進程多線程配合,以及語言級別數(shù)據(jù)管道表示上,可以進行改造和優(yōu)化。

  JDK9 會有 HTTP/2 client 端的能力,但毫無疑問會有更多更好的三方庫出現(xiàn),JDK 可以和這些三方庫通力合作,提供一個更好 API 界面和 SPI 參考實現(xiàn)。

  目前 Java 在云計算方面遇到的最大問題還是占用內(nèi)存過大。我個人認為從兩個方面來看:

  • 如果該應(yīng)用的確是長時間運行的服務(wù),可以考慮結(jié)構(gòu)清晰的單體結(jié)構(gòu),算下來總的內(nèi)存消耗并不會比多個微服務(wù)進程占用的更多。
  • 微服務(wù)應(yīng)用,未來可以采用編譯成本地代碼的方式,并使用優(yōu)化過的三方庫,甚至本地 so 文件,減少單個進程的過多內(nèi)存占用。
  • 安全框架更加清晰,SPI 可以允許三方庫提供更強大更高效的安全功能。
  • JavaEE 方向則有更多的改進的地方:
  • EJB 重構(gòu)目前的 Corba 分布通信基礎(chǔ),參考 gRPC 進行遠程系統(tǒng)調(diào)用。
  • 分解 EJB 規(guī)范,把 JVM 進程相關(guān)的特性,如注入 / 加強 / 事務(wù) / 安全都統(tǒng)一到 CDI 規(guī)范中;對 EJB 進行裁剪,保留遠程訪問特性和作為獨立執(zhí)行主體分布式對象能力。
  • 加強 JMS 和 MDB,媲美 Akka 目前的能力。
  • JaxRS 適度優(yōu)化,不必要依賴 Servlet,或者適度調(diào)整,來提供更大的能力。
  • JPA 借鑒 JDO,以及融入一部分特性,做到對 NoSQL 更良好的支持。

  一些個人的心得和經(jīng)驗分享

  軟件業(yè)有個 Hype Cycle 模型,有很多技術(shù)受到市場的追捧而成為明星,也有些身不逢時而備受冷漠。

  EJB 是一個廣泛被誤解的技術(shù),在企業(yè)應(yīng)用分布式計算方面,EJB 給出了非常完備的技術(shù)體系。只是目前所有的應(yīng)用服務(wù)器都實現(xiàn)的不夠好。對于目前打算轉(zhuǎn)型微服務(wù)設(shè)計的架構(gòu)師,EJB 也是一個非常值得學(xué)習(xí)借鑒的技術(shù)。

  Java 的慢是相對的,有些是當(dāng)前實現(xiàn)的不夠好。比如原來有人對 Java 的網(wǎng)絡(luò) IO 性能提出質(zhì)疑,然而穩(wěn)定的 Netty 框架出現(xiàn)后,就沒有人再懷疑 Java 處理網(wǎng)絡(luò) IO 的能力了,甚至在 JDK8 中自身的 NIO 也相當(dāng)出色。要知道 Java 為了實現(xiàn)跨平臺能力,采用的是各個操作系統(tǒng)的一個公共能力子集,而且其設(shè)計哲學(xué)就是給出 API 框架,實現(xiàn)是可以自行實現(xiàn)和加載服務(wù)的。

  Java 在處理界面方面,Swing 和 Swt 表現(xiàn)可圈可點(Idea 和 Eclipse 分別采用的圖形基礎(chǔ)庫),JavaFX 已經(jīng)運用到很多的行業(yè)軟件上。在瀏覽器界面表現(xiàn)上,SpringMVC 在模板渲染頁面方面使用者最多;GWT 似乎使用者不多,但基于 GWT 的 Vaddin 在國外企業(yè)中用戶眾多,而且很多服務(wù)器管理軟件也用 GWT 寫成;JSF 也在企業(yè)軟件中得到廣泛使用,狀態(tài)信息直接在后端進行管理,配合 js 前端框架,可以充分發(fā)揮各種技術(shù)的優(yōu)勢。

  CDI 規(guī)范和 SpringFramework 在服務(wù)器程序中作用類似,Spring 是一套設(shè)計優(yōu)良,完備的框架,CDI 具有更強的可擴展性。通過對注解的語義定義,一家公司可以維護一套自己的組件描述語言,來做到產(chǎn)品和項目之間的軟件快速復(fù)用。CDI 是定義軟件組件內(nèi)部模型的最佳方式,只可惜了解的軟件工程師實在太少。

  微服務(wù)架構(gòu)在互聯(lián)網(wǎng)應(yīng)用,快速開發(fā)運維管理方面,配合容器技術(shù)使用,有很強的優(yōu)勢。但并不是所有的應(yīng)用場景都適合微服務(wù):強事務(wù)應(yīng)用系統(tǒng),采用單體結(jié)構(gòu)的軟件體系設(shè)計,更容易從整體方面維護,也能獲得更優(yōu)的性能。Java 語言無論在微服務(wù)還是單體結(jié)構(gòu),都有成熟穩(wěn)定的軟件架構(gòu)供選擇使用。

  作者介紹:張建鋒,永源中間件共同創(chuàng)始人,原紅帽公司 JBoss 應(yīng)用服務(wù)器核心開發(fā)組成員。畢業(yè)于北京郵電大學(xué)和清華大學(xué),曾供職于金山軟件,IONA 科技公司和紅帽軟件。對于 JavaEE 的各項規(guī)范比較熟悉;開源技術(shù)愛好者,喜歡接觸各類開源項目;在分布式計算,企業(yè)應(yīng)用設(shè)計,移動行業(yè)應(yīng)用,Devops 等技術(shù)領(lǐng)域有豐富的實戰(zhàn)經(jīng)驗和自己的見解。

向AI問一下細節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI