自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

誰再把IDEA的Project比作Eclipse的Workspace,我就跟誰急

開發(fā) 前端
本文將著眼于幫你深入的介紹IntelliJ IDEA里最重要的兩個概念:Project和Module,它是最最最基礎(chǔ)也是最重要的,我認(rèn)為本文不僅適合使用IDEA的萌新,同樣適合使用IDEA的“老手”(曾經(jīng)eclipse的重度用戶尤甚)。

 前言

你好,我是A哥(YourBatman)。

有一個觀點(diǎn):若一個Java開發(fā)者能把IDEA玩得666,則技術(shù)一定不會差;但若玩不轉(zhuǎn)IDEA(如不會設(shè)置、定制、解決日常問題、快捷鍵等等),那大概率水平很一般。因?yàn)楦呤忠话愕糜懈呤值臉幼樱?/strong>你同意這個觀點(diǎn)嗎?

通過上篇文章 你也了解到,現(xiàn)今的Javaer絕大部分都使用IntelliJ IDEA作為IDE進(jìn)行開發(fā),但同時發(fā)現(xiàn)(從身邊同事調(diào)查)大部分同學(xué)都并不能很好的使用IDEA,其中表現(xiàn)最為突出的是IDEA里的ProjectModule兩個概念,混淆不清或者概念完全扭曲。

A哥是一個相對來講很注重基礎(chǔ)知識搭建的Javaer,所以對于最常用的工具也是如此,愿意花些時間去搞明白,包括頁布局、功能定制、插件、以及快捷鍵都會調(diào)為自己最順手的狀態(tài),畢竟工欲善其事,必先利其器。

本文將著眼于幫你深入的介紹IntelliJ IDEA里最重要的兩個概念:Project和Module,它是最最最基礎(chǔ)也是最重要的,我認(rèn)為本文不僅適合使用IDEA的萌新,同樣適合使用IDEA的“老手”(曾經(jīng)eclipse的重度用戶尤甚)。

本文提綱


版本約定

  • IntelliJ IDEA:2020.3.1

正文

IntelliJ IDEA相較于Eclipse可謂是后起之秀,2006年開始嶄露頭角,2012年整體性能上完敗Eclipse,2016年市場份額完成全面超越,一步步的逐漸成為JVM平臺的主流IDE。

正是由于有這樣的歷史進(jìn)程,有大批“老”程序員是從Eclipse過度到IDEA來的,因此就有了一個頗具代表性的概念對比表格,方便“遷移”:


誠然,IntelliJ IDEA的使用成本比eclipse略高,在那樣的歷史背景下,這張表格確實(shí)降低了“老”程序員們的遷移過度成本,即使現(xiàn)在看來這張表格的描述并不準(zhǔn)確,設(shè)置具有極大的誤導(dǎo)作用(副作用開始展現(xiàn)......)。

IDEA和eclipse的概念類比上,最“著名”的當(dāng)屬把IDEA的Project比作Eclipse的Workspace,回憶下你當(dāng)初是不是經(jīng)常聽到這樣的聲音?博客文章這樣說、培訓(xùn)機(jī)構(gòu)老師這樣說、甚至大學(xué)的老師也是教你這么去理解的。更有甚者,對于很多“中毒”很深的、曾經(jīng)的eclipse用戶來說,他們是這樣使用IDEA的:


實(shí)現(xiàn)了所謂的:IDEA在同一窗口顯示多個項(xiàng)目。若你發(fā)現(xiàn)你身邊有這么樣管理項(xiàng)目的同事,那么他是你的“前輩”沒跑了,因?yàn)殍F定是eclipse的資深用戶,然后遷移到IDEA來。

[[378641]]

這種做法是錯誤的,毫不相干的項(xiàng)目(遠(yuǎn)程調(diào)用不叫有關(guān)系)沒有理由放在同一視窗內(nèi),除了干擾還是干擾。Eclipse里有workspace工作空間的概念尚可理解,可IDEA里是絕對不要這么做。

在 IntelliJ IDEA 中,沒有類似于 Eclipse 工作空間(Workspace)的概念,而是提出了Project和Module這兩個概念。本文來告訴你,IntelliJ IDEA是如何管理項(xiàng)目Project、模塊Module以及它倆關(guān)系,看完之后你會發(fā)現(xiàn)單這一點(diǎn)IntelliJ IDEA就比Eclipse優(yōu)秀得多。

Project和Module概念

什么是Project

Eclipse中一個Workspace可以包括多個Project,而在IDEA里Project是頂級概念。

Project(翻譯為:項(xiàng)目)IntelliJ IDEA的頂級組織單元,它是個邏輯概念。一般來說一個Project代表一個完整的解決方案,如它可包含多個部分,如:

  1. 源代碼
  2. 構(gòu)建腳本
  3. 配置文件
  4. 文檔
  5. SDK
  6. 依賴庫
  7. ...

也就是說Project是個完整體,是個資源的集合,扔到任何地方都是可以被解釋的。

❝說明:建議把Project翻譯為項(xiàng)目,而非工程,不在一個維度。因?yàn)橐粋€module其實(shí)也可以理解為一個工程,避免混淆❞

什么是Module

模塊是是項(xiàng)目Project的一部分,必須隸屬于Project而存在。它可以獨(dú)立編譯、測試、運(yùn)行甚至部署。

模塊是分而治之思想的體現(xiàn),是降低大型項(xiàng)目復(fù)雜度的一種有效手段。模塊是可重用的,若需要,一個模塊可以被多個模塊引用,甚至多個Project項(xiàng)目引用(比如commons模塊)。

此處強(qiáng)烈不再建議你把Eclipse的Workspace引入進(jìn)來做類比,那只會把你帶跑偏了。細(xì)品這兩個概念定義,總結(jié)一下:

1.在IDEA中,Project項(xiàng)目是最頂級的結(jié)構(gòu)單元,一個IDEA視窗有且只能代表一個Project

現(xiàn)在知道為何把user、account、order扔到一個視窗里有多么的不合適了吧

2.一個Project由一個or多個Module模塊組成,對于大型項(xiàng)目來講一般會有N多個module組成,如dubbo項(xiàng)目結(jié)構(gòu)如下圖所示:


3.一個module模塊里,依舊可以有子模塊,曾經(jīng)可無限延伸(但不建議太多)

4.Project是個邏輯概念,Module才是最終的存在形式


錯誤使用


優(yōu)點(diǎn):

1.一個窗口,能看見全貌

弊端

2. 視窗功能不單一。account、order、user屬于不同項(xiàng)目,是為了解決不同問題而存在,沒有理由放在一起 3. 干擾性太強(qiáng)。比如他們?nèi)加蓄惤蠵rocessService,那么在你查找的時候永遠(yuǎn)無法“精確定位”


3.額外性能開銷。比如你只想開發(fā)user,但還得把其它的加載進(jìn)來,完全沒有必要嘛。

說明:idea不能像eclipse一樣close project的,畢竟人家那是workspace的概念,而idea同一視窗屬于同一項(xiàng)目,總不能說關(guān)閉某個模塊吧,模塊一般相關(guān)性很強(qiáng),完全沒必要單獨(dú)開/關(guān)

想一想,若你一個人負(fù)責(zé)了20+個項(xiàng)目,每次打開是不是得花上個幾分鐘呢?

4.概念上混亂。這么放在一起,其實(shí)就不是user項(xiàng)目、order項(xiàng)目了,而是user模塊、order模塊,很明顯概念上就不準(zhǔn)確了


正確使用


這種使用方式界面清爽,運(yùn)行流暢,解決了上面錯誤方式的所有弊端。

新建項(xiàng)目Project

萬丈高樓平地起,使用IDEA的第一步一定是新建一個項(xiàng)目Project:


或者你也可以在視窗內(nèi)部新建,頂部菜單欄File -> New -> 三選一:


三種創(chuàng)建方式:

  1. 創(chuàng)建一個全新項(xiàng)目
  2. 打開現(xiàn)有項(xiàng)目
  3. 從VCS版本控制系統(tǒng)里clone一個項(xiàng)目

本文就以1為例,因?yàn)?和3從本質(zhì)上講都叫打開項(xiàng)目,并不會經(jīng)歷創(chuàng)建流程。下面我們按步驟走一篇創(chuàng)建流程:

第一步:選擇創(chuàng)建項(xiàng)目的方式,本文選擇創(chuàng)建創(chuàng)建Java項(xiàng)目


第二步:選擇根據(jù)模版創(chuàng)建項(xiàng)目。這個在maven還沒出現(xiàn)之前挺有用,現(xiàn)在幾乎不用了,因此一般都不勾選


第三步:填寫項(xiàng)目名、項(xiàng)目位置(以及同步創(chuàng)建的模塊名、位置等,可選)


①:項(xiàng)目存儲位置,一般作為整個項(xiàng)目的根目錄

②:內(nèi)容根目錄

③:模塊文件存放的目錄

④:項(xiàng)目格式文件(IDEA負(fù)責(zé)識別,后面它還會出鏡)

More Setttings選項(xiàng)默認(rèn)是收起狀態(tài),也就是說大多數(shù)情況下創(chuàng)建時你并不需要修改同步創(chuàng)建的模塊的這些信息,而實(shí)際上也確實(shí)是這么干的。

點(diǎn)擊Finish,IDEA **100%**就會在新窗口(或者覆蓋本窗口)打開新創(chuàng)建的這個項(xiàng)目:


該項(xiàng)目在硬盤里的表現(xiàn)形式僅僅是一個文件目錄而已:


.idea文件夾的作用

每個Project項(xiàng)目都對應(yīng)1個 .idea文件夾(隱藏目錄),該項(xiàng)目所有特定設(shè)置都存儲在該.idea文件夾下,比如項(xiàng)目模塊信息、依賴信息等等。

一般來講它里面會有這些文件/目錄:

  • misc.xml:描述該項(xiàng)目一些混雜信息,如SDK、語言等級、項(xiàng)目輸出的目錄等等
  • modules.xml:描述該項(xiàng)目有哪些Module模塊
  • workspace.xml:描述視窗的信息。如Project窗口在左邊還是右邊,窗體大小,顏色,是否隱藏,滾動情況等等(每個Project都允許你個性化配置,規(guī)則都被記錄在這個文件里)
  • vcs.xml:使用的VCS工具信息,如Git

除了這些,一些插件也經(jīng)常會往這個目錄增加文件,如:

  • saveactions_settings.xml:saveaction插件的專屬配置文件
  • jarRepositories.xml:遠(yuǎn)程倉庫配置文件
  • encodings.xml:描述模塊文件夾編碼信息的配置文件
  • compiler.xml:描述每個module模塊使用的編譯器信息的文件。如使用1.8編譯,是否加了編譯參數(shù)-parameters等等都在這里體現(xiàn)

總的來講,這個文件夾里面的東西不用關(guān)心,由IDEA/插件自己自動維護(hù),我們只需要界面化操作即可。當(dāng)然嘍,若了解一二對于定位一些常見問題(如不知-parameters是否生效)是有幫助的。

新建模塊Module

創(chuàng)建好一個Project默認(rèn)會有一個同名的的module(Empty Project除外),如果項(xiàng)目比較小復(fù)雜度較低,一個模塊足矣。但是,稍微有點(diǎn)復(fù)雜性的項(xiàng)目一般都希望進(jìn)行模塊拆分,建立多個模塊,分而治之。比如:

  • hello-service:實(shí)現(xiàn)核心業(yè)務(wù)功能處理
  • hello-persistence:復(fù)雜持久化工作
  • hello-client:作為客戶端暴露出去

第一步:頂部菜單欄給該項(xiàng)目創(chuàng)建模塊

 

 

 當(dāng)然還有一種方式是在Project Structure里創(chuàng)建(這個咱們下篇文章再聊):

第二步:選擇該模塊類型,可以是Java項(xiàng)目、maven項(xiàng)目、Kotlin項(xiàng)目等等都行


第三步:給模塊命名,并制定該module模塊的存在位置。一般來講只需要寫名稱即可,模塊的路徑默認(rèn)會放在project目錄的子目錄下


關(guān)于目錄選擇再強(qiáng)調(diào)一遍:默認(rèn)情況下模塊路徑會在Project(或者父模塊)的子目錄下,但這并不是必須的,你也可以改為和Project的同級目錄也是可以的,邏輯上依舊屬于Project的模塊,不會有問題。但一般建議保持這種層級關(guān)系而不要修改~

  • ❝若是父子目錄,層級關(guān)系更明顯些,否則是一種plat平鋪目錄關(guān)系,看著會不太“舒服”❞

點(diǎn)擊Finish,在Project視窗就可以看見該模塊啦(層級結(jié)構(gòu)展示哦):


這個時候的Project - Module層級結(jié)構(gòu)圖是這樣子的:


這時我就拋出一個問題,若要實(shí)現(xiàn)下圖這種層次結(jié)構(gòu)(plat全部平級),新建模塊時需要注意些什么呢?


模塊創(chuàng)建好后,這時再看看.idea這個文件夾里的modules.xml,內(nèi)容為:


xxx.iml文件的作用

每個Module模塊都對應(yīng)一個同名的 .iml文件,用于描述該模塊的相關(guān)信息。如:SDK、語言等級、依賴、源代碼所在位置、輸出路徑等等。

總結(jié)

本文主題是介紹IDEA的Project和Module兩個重要概念,然后再通過具體示例的方式加深理解,講的還是比較清楚的(可能是全網(wǎng)最清楚的?),希望可以幫助到你加深對IDEA的理解,再也不要把IDEA的Project比作Eclipse的Workspace。

簡單總結(jié)一下本文內(nèi)容:

  • Project是一個不具備任何編碼設(shè)置、構(gòu)建等開發(fā)功能的概念,主要作用就是起到一個項(xiàng)目定義、范圍約束的效果(比如user項(xiàng)目,里面所有內(nèi)容應(yīng)該是為了解決user問題而存在的),你也可以理解它就是一個目錄,然后這個目錄的名字就代表項(xiàng)目名
  • Module模塊是代碼的實(shí)際表現(xiàn)形式。在默認(rèn)情況下,一個Project對應(yīng)一個Module,它倆“合二為一”,對于中大型項(xiàng)目來說,一般都會使用多模塊編程

下篇預(yù)告:在IDEA中,對項(xiàng)目結(jié)構(gòu)Project Structure的設(shè)置尤為重要,下篇就為你剖析該頁面每個tab選項(xiàng),到底如何玩轉(zhuǎn)它,具備一個高手的樣子,這對你理解Maven項(xiàng)目也將非常非常有幫助,敬請關(guān)注


本文思考題

看完了不一定懂,看懂了不一定會。來,文末3個思考題幫你復(fù)盤:

  1. IDEA的Project和eclipse的workspace的本質(zhì)區(qū)別在哪里?
  2. 如何給Project/module單獨(dú)添加依賴庫?
  3. IDEA模塊的.iml文件有什么作用?

 

責(zé)任編輯:姜華 來源: BAT的烏托邦
相關(guān)推薦

2020-10-30 09:02:15

Redis內(nèi)存數(shù)據(jù)

2020-12-17 09:17:36

servlet容器

2014-07-17 11:36:27

Android Stu使用教程

2017-11-30 15:25:04

EclipseGo項(xiàng)目

2009-11-27 11:16:30

2015-05-06 10:11:48

2012-03-20 09:20:54

IntelliJEclipseJava

2019-10-08 10:37:46

設(shè)計技術(shù)程序員

2020-08-09 17:44:51

Python數(shù)據(jù)分析工具

2021-11-26 09:40:37

EclipseIDEA開發(fā)

2020-09-04 14:18:23

SpringBoot考試系統(tǒng)學(xué)科

2017-12-14 14:19:52

IntellijIDEA快捷鍵

2010-06-23 15:09:38

SharePoint

2025-04-17 04:22:00

Log插件日志管理

2023-12-08 07:38:13

GptsOpenAIChatGPT

2019-08-12 10:27:34

前端程序員網(wǎng)絡(luò)

2013-10-31 15:52:11

2013-06-07 10:18:00

EclipseIntelliJ ID

2023-02-08 18:08:16

2013-05-15 09:18:52

4G牌照TD-LTE4G
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號