IDEA 非常重要的一些設置項 → 一連串的問題差點讓我重新用回 Eclipse !


開心一刻

  建築行業內,我看過的最凶殘笑話(IT行業內好一致!)

  上聯:一天晚上兩個甲方三更半夜四處催圖只好周五加班到周六早上七點畫好八點傳完九點上床睡覺十分痛苦

  下聯:十點才過九分甲方八個短信七個電話居然要六處調整加五張圖紙四小時交三個文本兩天周末只睡一個小時

  橫批:用原來的

內心的獨白

寫作背景

  2017 從 eclipse 換到 IDEA,適應了一段時間,后面一直用 IDEA 2018 版,使用期間偶爾出現一些小問題,但不多,沒太注意

  最近換了電腦,開發環境得重新搭,順便把 IDEA 更新下。本來打算用 2020 版的,可網上對 2020 版的評論一致比較差,所以我就放棄做勇士了,用的是 2019.3.5 版本

  切了版本后,使用期間陸陸續續暴露了不少問題,有些問題還花了不少時間來處理,期間甚至有了放棄 IDEA,重新投抱 Eclipse 的想法,但是后面冷靜一想,Eclipse 幾年沒用,都忘完了,重新撿起來的成本可能更高,所以痛定思痛,決定將 IDEA 的這些比較常用的設置全部整理一下,方便以后自己查閱,也方便遇到同樣問題的小伙伴進行問題排查與處理

  需要大家注意是,樓主用的是 IDEA 2019.3.5 版本,可能和大家的版本不同,版本不同,配置項會有細微的區別,大家不要完全一致的去對比

全局設置與當前設置

  其實 IDEA 安裝完成的時候就提示我們進行全局設置,但是往往被我們忽略了

  當我們打開工程后,往往設置的是當前工程的設置,而不是全局設置,所以當我們用新窗口打開新的工程時,發現新窗口的設置都是默認的,而不是我們之前設置的,這就有點不爽了

  那如果我們在 IDEA 安裝的時候沒有進行全局設置,還能進行全局設置嗎? 答案是肯定的,可以在 IDEA 窗口進行當前設置和全局設置,如下圖

  

  Settings 表示的是當前設置,Other Settings 表示的是全局設置;不同的 IDEA 版本,Other Settings 代表的都是全局設置(未來不一定,但是歷史是這樣),只是 Other Settings 下內容可能會有所不同

  如果既進行了 Settings 設置,又設置了 Other Setting, 那么當前工程生效的是 Settings 中的設置

  后續講到的一些設置若非特殊說明都是在全局設置下進行,主要是為了強調下全局設置的重要性(可能只是樓主后知后覺,汗...)

必定修改

  Project SDK

    配置成我們安裝的 JDK,目前用的比較多的是 1.8 版本; 配置如下

    

  項目文件編碼

    工程編碼我需要統一,基本統一成 UTF-8,設置如下

    

    都選擇 UTF-8

    如果不選擇 UTF-8,可能會編譯不報錯,但是啟動時卻報錯:Error:(15,31) java: 找不到符號

  自動編譯

    默認情況下,自動編譯是關閉的,我們可以按下圖進行開啟

    

     將復選框勾上則開啟自動編譯,但后面有說明:非 running 或 debugging 時才生效

  智能導包

    效果就是,當我們輸入 List,能夠自動導入 java.util.List ,設置如下

    

    兩個復選框都需要勾上

  行號顯示

    顯示代碼行號,配合日志能快速地定位到出問題的代碼,設置如下(這個只能在 Settings 中進行設置)

    

    需要將復選框勾上;勾選上之后,每一行代碼前就會有行號顯示,如下所示

    

  制表符設置

    主要時考慮到不同的編輯器對 Tab 的處理不同,所以統一成 4 個空格來處理

    

     復選框不要勾

  maven 設置

    IDEA 自帶 maven,但往往需要修改成我們自己的 maven,我們的 maven 有很多自定義的配置,如私有倉庫等

    配置如下

    

     標記的地方替換成我們自己的 maven, 至於 Local repository,會自動加載 maven settings.xml 中的倉庫地址,一般不用覆蓋修改

  構建/運行操作不委托給 maven

    默認情況下對項目的構建和運行是 IDEA 自己負責的,這樣就可能導致構建和運行時無法找到 maven 倉庫中的相關 jar 包,從而出現:Error:(6, 34) java: 程序包xxx不存在的錯誤

    進行如下配置,將構建/運行操作委托給 maven,這樣依賴的 jar 包都能正確找到

    

    復選框勾上后,構建和運行操作就委托了 maven

    但是這樣設置后運行單個 main 方法都會輸出一堆的 maven 日志,而這個時候我們往往只想關注 main,而不想關注 maven

    所以,Delegate IDE build/run actions to Maven 前的復選框不要勾上,然后指定 idea 中的本地 maven 倉庫

    

    這樣設置后,既不會報包找不到的錯誤,也不會將構建和運行操作委托給 maven

推薦修改

  多行顯示文件 Tab

    默認情況下多行 Tab 是單行顯示的,效果如下

    

    所有打開的文件 Tab 顯示在一行,顯示不下的收縮起來(越久未被操作的文件越容易被收縮);文件多了收縮起來,還是不太方便文件的切換操作,推薦多行顯示,配置如下(只能在 Settings 下設置)

    

    復選框不要勾上,設置了后效果如下

    

    這樣文件切換起來更方便

  取消 import xxx.*

    當我們 Java 類中導入的某個包下類超過指定個數,就會換成用 * 號來代替,例如:import java.utils.*;

    * 代表的是導入包下所有類,不夠直觀,也沒必要,需要什么就導入什么是最好的

    

    Class count to use import with '*' 表示的是:導入了同個包下多少的類,就將這些導入替換成 *, 默認是 5

    Names count to use static import with '*' 則表示的是:靜態導入了同個類中多少的靜態常量,就將這些導入替換成 *, 默認是 3

    我們將這兩個值配置大一些,那么就不會 import * 了

  類注釋模板

    阿里規約中有這么一條,類必須加注釋,並且必須要有 author

    類注釋還是很有必要的,可以追溯到人,便於業務的溝通

    配置如下

    

    想加什么參數就加什么;設置好后,我們新建一個類,就會自動帶上注釋,如下所示

    

  快速文檔顯示

    默認情況下,IDEA 是不顯示快速文檔的,我們把鼠標放到方法調用(或接口實現)上,是不能提示接口中的注釋文檔的,如下所示

    

    每次看方法的說明,還得去對應的接口中去看,有點麻煩;但 IDEA 是提供了對應的配置項來開啟快速文檔顯示的(只能在 Settings 中進行設置,但是全局生效)

    

    將標記的復選框勾上,保存即可;之后效果如下

    

    不只是針對方法的快速文檔,還支持類、屬性的快速文檔

  文件夾層級顯示

    先捋清下名稱的問題,免得大家理解上出現分歧

    

    可以看到,在 java 下創建的是 Package ,在其他下創建的是 Directory ,反映到操作系統的文件系統上,都叫文件夾,所以我們接下來我們都以文件夾來說事

    默認情況下,IDEA 是將空文件夾(文件夾下只有一個文件夾,沒有文件)折疊顯示的,如下所示

    

    這樣層級結構不深,看起來確實簡單直白一些,但這樣往往會迷惑我們,導致關於配置文件路徑的問題不好排查,樓主就在這上面栽了跟頭,配置 mybatis 后出現了 Invalid bound statement (not found) ,卻排查了很久

    IDEA 中是可以一次創建多級文件夾的(真的嗎?),如下所示

    

    看着似乎很正常,我們關閉文件夾折疊顯示,讓文件夾顯示完整的層級結構

    

    發現什么了沒,還不直觀? 我們去磁盤上看

    

    可以看到, resources 下的 emall.dao 是一個文件夾的名字,而不是 emall 是一個文件夾,並且它下面有個子文件夾 dao ,所以導致樓主配置的 mybatis 映射文件 com/lee/emall/dao/*.xml 就找不到了,也就出現了錯誤 Invalid bound statement (not found) 

    總結下, java 文件夾下支持一次性創建多級 Packages ,其他文件夾下不支持一次性創建多級 Directory ;文件夾的折疊顯示最好關閉,萬一不小心犯了與樓主一樣的錯,方便排查

可能修改

  maven Ignored files

    Settings 下有這么個設置

    

    理論上來講,這個列表中的復選框都不能勾選(默認也都不會勾選),如果勾選了,那么就被勾選了的 pom.xml 對應的工程就不會被當作 maven 工程,后果可想而知:不是 maven 工程就會有依賴找不到的問題,項目就會啟動失敗

    樓主不知道怎么回事就勾上了其中一個,出現如下症狀

    

    maven 工具窗口下該 maven 工程顯示成了灰色,特別與眾不同;然后啟動該工程的時候,提示各種依賴都找不到,真是斃了狗

  Method Breakpoints

    正常情況來說,我們是不會直接在方法名上打斷點的,斷點往往是打在方法體上的某一行上,但是樓主不知道怎么回事就打了,導致以 debug 方式啟動不了工程,並提示:Method breakpoints may dramatically slow down debugging

    打開 Breakpoints 面板看看(快捷鍵:Ctrl+Shift+F8 )

    

    一個斷點打在了 UserService 接口中的方法上,一個接口打在了實現類 UserServiceImpl 的方法名上

    一般而言不會出現這種情況,就怕大家像樓主一樣不小心,在方法名上打了斷點,並導致項目 debug 不起來,知道如何處理就好

    逐個選中,remove 就好,如下圖所示

    

總結

  1、遇到問題,不能立馬想到去怎么處理的,盡快利用網絡去查,千萬不要一頭扎進自我認為中去,太費時了,最后還得求助於網絡

    網絡搜索的話,關鍵字非常重要,描述的越清楚,命中率越高;如果確實不好描述,那就多換關鍵字去查

  2、有些配置是需要勾選復選框,有些是不能勾選,大家要看清楚了

  3、文中的 IDEA 配置修改分了三種:必須、推薦、可能,只囊括了一部分,有些未考慮到的歡迎大家補充

    可能級別中的問題基本都是誤操作,大家留個印象就好,萬一碰到了知道怎么處理

  4、要學會多總結,包括各個方面的總結,這樣我們才能越來越強大!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM