街邊食堂:當下“已經過時”的Java後端技術有哪些?

街邊食堂:當下“已經過時”的Java後端技術有哪些?

我判斷的依據主要有以下幾點:

  1. 實際開發能否用到?
  2. 是否有助於加深對技術的理解?
  3. 對面試是否有用?

JSP

JSP在實際開發中,主要是作為MVC模型中的V(View)層出現的。當然,View層的渲染技術除了JSP,還有FreeMaker、Velocity等。

JSP作為頁面模板,在後端通過MVC框架渲染成HMTL,然後再發送到客戶端(例如瀏覽器)來呈現。這也就是我們常說的“前後端不分離”,“混合式”開發。

而當前,包括我所在的公司,以及大部分互聯網公司。要麼已經拋棄這種模式,要麼正在拋棄的路上,而轉向徹底的“前後端分離”。

在“前後端分離”模式下,後端只負責提供服務接口(例如REST),而前端(例如HTML5)通過接口發送/獲取,呈現數據(例如JSON格式)。

這樣,在後端,原來的MVC框架,某種意義上已經演變為MC框架。因此,與V(View)相關的一切模板技術都失去了學習的必要,其中當然也包括JSP。所以,後來的Java學習者,我的建議是:

完全可以放棄對JSP的學習

Struts

在Java後端開發中,MVC模型還是主流。而Struts作為一個MVC框架,單從技術上來說,還是很優秀的。

但是,現在Spring實在是太強勢了,越來越成為Java開發中的“一站式”工具包,其中的一個利器就是Spring MVC。

望名知意,Spring MVC也是一個MVC框架。而且因為它是Spring的親兒子,自然和Spring契合的非常完美。

同時,在設計之初,Spring MVC就參照了其他MVC框架的優缺點(包括Struts),所以用起來非常爽。因此,在MVC框架領域,Spring MVC大有一統天下的趨勢。

因此現在,很多公司,老的Struts項目還在維護。但新的項目開發,更多轉向了Spring MVC。因此,如果你是Java新手,正在學習中,我的建議是:

不要再學習Struts了,從Spring MVC開始吧!

Hibernate

Hibernate作為老牌的OR映射框架,功能非常強大,涵蓋面非常廣。但這既是它的優點,同時也成為它的“負擔”,是開發人員“不能承受之重”。

Hibernate的設計初衷,是為了最大程度的解放程序員,完全隔離數據庫,實現徹底的OR映射。程序員甚至可以不寫一行SQL語句,單通過配置就能實現對數據庫的操作。

當然,為了實現這個目標,Hibernate也設計的非常複雜、非常精巧。就不可避免的帶來以下副作用:

  1. 學習成本高
  2. 配置複雜
  3. 調優困難

前兩點不難理解,單說“調優困難”。

因為Hibernate的設計目標是徹底的OR映射,徹底的隔離SQL語句。但必然會帶來一定的性能損失。大部分情況下,應用如果對性能不敏感,Hibernate也沒問題。但應用一旦對性能敏感,有SQL級別調優的需求,Hibernate的優點反而成為缺點。

雖然Hibernate也支持SQL級別的調優,但因為框架設計的過於複雜和精巧,這就需要開發人員對Hibernate理解的非常透徹,這就帶來了更高的學習成本。

而現在最流行的MyBatis,作為一個“混合式”,輕量級OR映射框架,既繼承了Hibernate的優點,同時也吸取了他的教訓。在支持配置的同時,又能接觸SQL,從而帶來了更多靈活性(包括調試、優化)。

當前,在實際開發中,Hibernate使用的越來越少了。大家更偏愛MyBatis這種輕量級框架。所以,對後來學習者,我的建議是:

不需要再學習Hibernate了,學MyBatis就夠了。”

Servlet(要精通)

當然,現在不會有任何公司,再用純粹的Servlet來時實現整個Web應用,而是轉向一些更高級的技術(例如各種MVC框架)。因此,會給人一種錯覺:Servlet已經過時,後來者就不需要再學習了。

在這裡,我可以非常負責任的說:這種觀點是極端錯誤,極端不負責任的。

Servlet不僅要學,而且要學深,學透。

當前,Servlet雖然不再是一個主流web開發技術,但依然是Java Web開發技術的基礎,是Java Web容器的基石,是行業標準。而現在流行的各種MVC框架(包括SpringMVC),在最底層,還是以 Servlet為基礎的。

為此,我畫了一個簡單的圖(不準確,會意即可):

街邊食堂:當下“已經過時”的Java後端技術有哪些?

所以,如果你想要徹底掌握某個MVC框架,則必須徹底理解Servlet。

而且,Servlet作為一個基礎設施。精通它,不僅有助於理解各種MVC框架。即使Servlet本身,也有很多實用價值。

如果你深刻理解了Servlet的生命週期,就可以在底層做很多事情。譬如在Request進來的時候,進行攔截,進行權限的判定。也可以在Response發出的時候,進行攔截,統一檢查、統一附加。

所以,如果你正在學習Java,對Servlet,我的建議是:

Servlet不僅要學,而且要學深,學透

其他

目前在國內,Java更多是作為web後端技術出現的。因此在實際學習中,很多技術就不符合“國情”,學習的現實意義不大。下面我就簡單列舉下。

1.Applet

作為頁面插件技術,不用多說,連flash都快被淘汰了,更無論從未流行的applet。

2.Swing

作為桌面UI框架。且不說本身設計的咋樣。現實開發中,我接觸的桌面應用,要麼用C++(例如MFC),要麼用C#(Winform、WPF)。所以,Swing就沒有學習的必要了。

3.XML

XML現在還在廣泛應用。但作為一個web數據傳輸格式,正在逐漸被JSON替代。所以,對Java後端學習來說,XML簡單瞭解即可。至於龐雜的XML操作API(例如XPath),完全不必學習。將來真要用到,再查也不遲。

最後

上面是我的一家之言,肯定有武斷之處,見諒!

我也分享一套自己整理的Java系統學習資料,裡面包含的是最新的架構技術,給大家福利的同時也證明我不是憑空亂談。

街邊食堂:當下“已經過時”的Java後端技術有哪些?

整理不易,轉發+關注後臺私信“Java學習”即可獲取,祝你學習順利。


分享到:


相關文章: