大家好,我是小林。很多學 Java 的同學都會關(guān)心一個問題:有哪些過時的、可以不必再學習的 Java 知識?
針對這個問題,知乎上一位大佬給出了自己的見解,回答非常專業(yè),分享給大家。
原文鏈接:https://www.zhihu.com/question/305924723/answer/557800752
注意,以下僅代表原作者本人的觀點,大家如果有其他的想法,歡迎留言區(qū)分享。
我判斷哪些技術(shù)不用學習的依據(jù)主要有以下幾點:
實際開發(fā)能否用到?
是否有助于加深對技術(shù)的理解?
對面試是否有用?
JSP
JSP在實際開發(fā)中,主要是作為MVC模型中的V(View)層出現(xiàn)的。當然,View層的渲染技術(shù)除了JSP,還有FreeMaker、Velocity等。
JSP作為頁面模板,在后端通過MVC框架渲染成HMTL,然后再發(fā)送到客戶端(例如瀏覽器)來呈現(xiàn)。這也就是我們常說的“前后端不分離”,“混合式”開發(fā)。
而當前,包括我所在的公司,以及大部分互聯(lián)網(wǎng)公司。要么已經(jīng)拋棄這種模式,要么正在拋棄的路上,而轉(zhuǎn)向徹底地 “前后端分離”。
在“前后端分離”模式下,后端只負責提供服務(wù)接口(例如REST),而前端(例如HTML5)通過接口發(fā)送/獲取,呈現(xiàn)數(shù)據(jù)(例如JSON格式)。
這樣,在后端,原來的MVC框架,某種意義上已經(jīng)演變?yōu)镸C框架。因此,與V(View)相關(guān)的一切模板技術(shù)都失去了學習的必要,其中當然也包括JSP。所以,后來的Java學習者,我的建議是:
“完全可以放棄對JSP的學習。”
Struts
在Java后端開發(fā)中,MVC模型還是主流。而Struts作為一個MVC框架,單從技術(shù)上來說,還是很優(yōu)秀的。
但是,現(xiàn)在Spring實在是太強勢了,越來越成為Java開發(fā)中的“一站式”工具包,其中的一個利器就是Spring MVC。
望名知意,Spring MVC也是一個MVC框架。而且因為它是Spring的親兒子,自然和Spring契合得非常完美。
同時,在設(shè)計之初,Spring MVC就參照了其他MVC框架的優(yōu)缺點(包括Struts),所以用起來非常爽。因此,在MVC框架領(lǐng)域,Spring MVC大有一統(tǒng)天下的趨勢。
因此現(xiàn)在,很多公司,老的Struts項目還在維護。但新的項目開發(fā),更多轉(zhuǎn)向了Spring MVC。因此,如果你是Java新手,正在學習中,我的建議是:
“不要再學習Struts了,從Spring MVC開始吧!”
Hibernate
Hibernate作為老牌的 ORM映射框架,功能非常強大,涵蓋面非常廣。但這既是它的優(yōu)點,同時也成為它的“負擔”,是開發(fā)人員“不能承受之重”。
Hibernate的設(shè)計初衷,是為了最大程度地解放程序員,完全隔離數(shù)據(jù)庫,實現(xiàn)徹底的OR映射。程序員甚至可以不寫一行SQL語句,單通過配置就能實現(xiàn)對數(shù)據(jù)庫的操作。
當然,為了實現(xiàn)這個目標,Hibernate也設(shè)計地非常復雜、非常精巧。就不可避免的帶來以下副作用:
學習成本高
配置復雜
調(diào)優(yōu)困難
前兩點不難理解,單說“調(diào)優(yōu)困難”。
因為Hibernate的設(shè)計目標是徹底的OR映射,徹底的隔離SQL語句。但必然會帶來一定的性能損失。大部分情況下,應用如果對性能不敏感,Hibernate也沒問題。但應用一旦對性能敏感,有SQL級別調(diào)優(yōu)的需求,Hibernate的優(yōu)點反而成為缺點。
雖然Hibernate也支持SQL級別的調(diào)優(yōu),但因為框架設(shè)計的過于復雜和精巧,這就需要開發(fā)人員對Hibernate理解的非常透徹,這就帶來了更高的學習成本。
而現(xiàn)在最流行的MyBatis,作為一個“混合式”,輕量級OR映射框架,既繼承了Hibernate的優(yōu)點,同時也吸取了他的教訓。在支持配置的同時,又能接觸SQL,從而帶來了更多靈活性(包括調(diào)試、優(yōu)化)。
當前,在實際開發(fā)中,Hibernate使用得越來越少了。大家更偏愛MyBatis這種輕量級框架。所以,對后來學習者,我的建議是:
“不需要再學習Hibernate了,學MyBatis就夠了。”
Servlet(要精通)
當然,現(xiàn)在不會有任何公司,再用純粹的Servlet來實現(xiàn)整個Web應用,而是轉(zhuǎn)向一些更高級的技術(shù)(例如各種 MVC 框架)。因此,會給人一種錯覺:Servlet已經(jīng)過時,后來者就不需要再學習了。
在這里,我可以非常負責任地說:這種觀點是極端錯誤,極端不負責任的。
Servlet不僅要學,而且要學深,學透。
當前,Servlet雖然不再是一個主流web開發(fā)技術(shù),但依然是Java Web開發(fā)技術(shù)的基礎(chǔ),是Java Web容器的基石,是行業(yè)標準。而現(xiàn)在流行的各種MVC框架(包括SpringMVC),在最底層,還是以 Servlet為基礎(chǔ)的。
為此,我畫了一個簡單的圖(不準確,會意即可):
圖片
所以,如果你想要徹底掌握某個MVC框架,則必須徹底理解Servlet。
而且,Servlet作為一個基礎(chǔ)設(shè)施。精通它,不僅有助于理解各種MVC框架。即使Servlet本身,也有很多實用價值。
如果你深刻理解了Servlet的生命周期,就可以在底層做很多事情。譬如在Request進來的時候,進行攔截,進行權(quán)限的判定。也可以在Response發(fā)出的時候,進行攔截,統(tǒng)一檢查、統(tǒng)一附加。
所以,如果你正在學習Java,對Servlet,我的建議是:
“Servlet不僅要學,而且要學深,學透。”
其他
目前在國內(nèi),Java更多是作為web后端技術(shù)出現(xiàn)的。因此在實際學習中,很多技術(shù)就不符合“國情”,學習的現(xiàn)實意義不大。下面我就簡單列舉下。
1)Applet
作為頁面插件技術(shù),不用多說,連flash都快被淘汰了,更無論從未流行的applet。
2)Swing
作為桌面UI框架。且不說本身設(shè)計得咋樣。現(xiàn)實開發(fā)中,我接觸的桌面應用,要么用C++(例如MFC),要么用C#(Winform、WPF)。所以,Swing就沒有學習的必要了。
3)JDBC
作為較低層的數(shù)據(jù)庫基礎(chǔ)設(shè)施,JDBC被很多框架(例如MyBatis)支持。但在實際開發(fā)中,程序員即使不了解也無大礙。因此,雖然我不能建議你放棄JDBC學習,但如果你時間有限,完全可以把它的優(yōu)先級排低一點。
4)XML
XML現(xiàn)在還在廣泛應用。但作為一個web數(shù)據(jù)傳輸格式,正在逐漸被JSON替代。所以,對Java后端學習來說,XML簡單了解即可。至于龐雜的XML操作API(例如XPath),完全不必學習。將來真要用到,再查也不遲。
審核編輯 :李倩
-
JAVA
+關(guān)注
關(guān)注
19文章
2974瀏覽量
104969 -
模型
+關(guān)注
關(guān)注
1文章
3298瀏覽量
49063 -
MVC
+關(guān)注
關(guān)注
0文章
73瀏覽量
13890
原文標題:一些已經(jīng)淘汰的 Java 技術(shù),別再學了!
文章出處:【微信號:小林coding,微信公眾號:小林coding】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
相關(guān)推薦
評論