歡迎光臨
每天分享高質量文章

為什麼比起 IntelliJ IDEA,我仍然更喜歡 Eclipse

來自:碼農網

連結:codeceo.com/article/why-i-prefer-eclipse-over-intellij-idea.html

原文:https://dzone.com/articles/i-still-prefer-eclipse-over-intellij-idea              

譯者:碼農網 – 小峰

這麼多年來,我觀察到滾滾歷史潮流正在從Eclipse湧向IntelliJ IDEA。去年,兩者的使用率幾乎相等,但是我感覺天平正在漸漸傾向IDEA。


IDEA就像IDE中的iPhone——它的使用者會告訴你“一旦你習慣之後,你會覺得它更好用”,或者“你怎麼還在使用Eclipse?”亦或是“IDEA太棒了,每個人都應該換成IDEA”,等等。



在過去的12年時間裡,我主要使用Eclipse,但是在某些情況下,我使用IDEA——在我編寫Scala的時候,編寫Android的時候,以及最近——由於Eclipse未能為Java 9發行版做好準備,所以經過半天的努力之後,我只能切換到IDEA,直到Eclipse終於有了一個可用的Java 9版本(包括Maven和其他東西)。


我總是很快地回到Eclipse。我仍然更偏愛它。不僅僅是因為我已經內化了所有的關鍵字組合(你可以在IDEA中重用這些組合),也是因為在IDEA中還有一些我覺得更糟糕的東西。當然,IDEA有許多很酷的功能,如程式碼改進建議,以及它有實際上無所不能的有效外掛。但我發現一些與更基本的開發工作流程和體驗有關的問題。這些無法用糖衣包裹的“炮彈”是:


1、專案不是自動構建的(預設情況下)


專案不是自動構建的(預設情況下),所以你可以以編譯錯誤結束,直到你開啟一個非編譯檔案或者執行一個構建。然後開啟自動構建,讓計算機爬動起來。我知道我的計算機需要升級,但這不是重點——沒有“構建在變化上”對第一次嘗試IDEA的我來說是一個巨大的“驚喜”。


我最近在Twitter上抱怨說,這居然“是一個功能”。依據貌似是如果你使用重構,那就不應該發生。但是,有數十起案例表明它確確實實發生了。透過新增方法引數、更改引數型別、刪除引數(此處IDE無法根據型別推斷刪除哪個引數)或透過更改傳回型別來重構。另外,Maven / Gradle依賴關係的改變可能會引入你無法看到的編譯問題。這根本不是一個合理的預設值,並且我認為效能問題是它仍然預設的唯一原因。這使得體驗變得更糟。


2、每個螢幕只能有一個專案。


也許那些只有綠地專案的小公司也是存在的。但是你至少偶爾需要一個單獨的專案——無論是“實驗”,還是“工具”,或者其他什麼。多模組Maven專案(IDEA處理良好)是不夠的。所以每當你需要走出你的主要專案時,你會啟動另一個螢幕。除了糟糕的可用性之外,它的記憶體加倍,痛苦加倍。


3、說起記憶體,IDE似乎比Eclipse更耗費記憶體。


我沒有這方面的代表性基準,但是我知道現在我家裡的8 GB RAM對於開發來說太小了,不過一直沒換。


4、它感覺沒有那麼響應和笨重。


有一點小小的延遲,不好說,但是“我感覺得到”。我在某個地方讀到過說IDE過度地重畫螢幕元素,所以這可能就是原因。Eclipse感覺更順暢(我知道這不是一個合適的論據,但我也沒有更精確的資料了)。


5、機智如我很聰明地圍繞專案有“unused methods”和“never assigned fields”。


由於使用Spring,所以這些方法和欄位是控制器方法和自動裝配欄位。也許一些Spring外掛會照顧到這一點,但是Spring並不是唯一使用反射的框架。即使是POJO上的getter和setter也會得到unused警告。這些警告有什麼問題?這些警告是貶值的。它們現在沒有任何意義。類也沒有“黃色”指示器,所以你實際上看不到警告的數量。Eclipse能夠更好地顯示警告,而且誤報也不太常見。


6、呼叫層次稍差。


呼叫層次稍差但是由於這對於我而言是最重要的IDE功能(還有重構也是),所以我一定要著重說明。它不會給你沒有明確定義的預設建構式的呼叫層次結構。另外,我所看到的是,IDEA使用者並不經常使用呼叫層次結構功能。我認為在呼叫層次結構之前,“查詢取用”透過UI也更加明顯,所以一些IDEA使用者甚至不知道呼叫層次結構是什麼,而是反覆地“查詢取用”。這隻是IDE的缺陷之一。


7、在輸出控制臺中不進行搜尋。


為什麼我有了IDE還必須複製輸出並貼上到文字編輯器才能搜尋?先等等,我得澄清一下,控制檯確實有搜尋。但是當我執行(Spring Boot)應用程式時,它會在底部不是控制檯的面板中輸出東西,並且沒有搜尋。


8、CTRL +箭頭預設跳過整個單詞,而不是“駱峰式”單詞。


這是可配置的,但又是一個奇怪的預設值。幾乎大家總是希望能夠逐個單詞(在駝峰式大小寫情況下)地遍歷變數,而不是跳過整個變數(方法/類)名稱。


9、幾年前,當我將它用於Scala時,那個專案從未真正編譯過。但是我猜那更多的是Scala的錯,而不是IDE。


如果你說,除了前兩個,其餘都不是重大問題,那我也同意。但是隨著一個個問題的累加,最終,這些稻草壓彎了駱駝。所以,我又回到了Eclipse的懷抱。當然你也可以對這些問題視而不見,這是你的選擇自由。


●本文編號569,以後想閱讀這篇文章直接輸入569即可

●輸入m獲取文章目錄

推薦↓↓↓

 

C/C++程式設計

更多推薦18個技術類微信公眾號

涵蓋:程式人生、演演算法與資料結構、駭客技術與網路安全、大資料技術、前端開發、Java、Python、Web開發、安卓開發、iOS開發、C/C++、.NET、Linux、資料庫、運維等。

贊(0)

分享創造快樂