maveneclipse源碼-ag真人国际官网
① 用好這個idea插件,寫代碼效率至少提升5倍!
還在編寫無聊枯燥又難以維護的pojo嗎?潔癖者的春天在哪裡?請看lombok!
在過往的java項目中,充斥著太多不友好的代碼:pojo的getter/setter/tostring;異常處理;i/o流的關閉操作等等,這些樣板代碼既沒有技術含量,又影響著代碼的美觀,lombok應運而生。
首先說明一下:任何技術的出現都是為了解決某一類問題的,如果在此基礎上再建立奇技淫巧,不如回歸java本身。應該保持合理使用而不濫用。
lombok的使用非常簡單,下面我們一起來看下:
1)引入相應的maven包:
lombok的scope=provided,說明它只在編譯階段生效,不需要打入包中。事實正是如此,lombok在編譯期將帶lombok註解的java文件正確編譯為完整的class文件。
2)添加ide工具對lombok的支持:
idea中引入lombok支持如下:
點擊file--settings設置界面,安裝lombok插件:
點擊file--settings設置界面,開啟annocationprocessors:
開啟該項是為了讓lombok註解在編譯階段起到作用。
eclipse的lombok插件安裝可以自行網路,也比較簡單,值得一提的是,由於eclipse內置的編譯器不是oraclejavac,而是eclipse自己實現的eclipsecompilerforjava(ecj).要讓ecj支持lombok,需要在eclipse.ini配置文件中添加如下兩項內容:
-xbootclasspath/a:[lombok.jar所在路徑]
-javaagent:[lombok.jar所在路徑]
3)lombok實現原理:
自從java6起,javac就支持「」規范,只要程序實現了該api,就能在javac運行的時候得到調用。
lombok就是一個實現了"jsr269api"的程序。在使用javac的過程中,它產生作用的具體流程如下:
javac對源代碼進行分析,生成一棵抽象語法樹(ast)
javac編譯過程中調用實現了jsr269的lombok程序
此時lombok就對第一步驟得到的ast進行處理,找到lombok註解所在類對應的語法樹(ast),然後修改該語法樹(ast),增加lombok註解定義的相應樹節點
javac使用修改後的抽象語法樹(ast)生成位元組碼文件
4)lombok註解的使用:
pojo類常用註解:
@getter/@setter:作用類上,生成所有成員變數的getter/setter方法;作用於成員變數上,生成該成員變數的getter/setter方法。可以設定訪問許可權及是否懶載入等。
packagecom.trace;importlombok.accesslevel;importlombok.getter;importlombok.setter;/***createdbytraceon2018/5/19.*desc:測試類*/@suppresswarnings("unused")publicclasstestclass{publicstaticvoidmain(string[]args){}@getter(value=accesslevel.public)@setter(value=accesslevel.public)publicstaticclassperson{privatestringname;privateintage;privatebooleanfriendly;}publicstaticclassanimal{privatestringname;privateintage;@getter@setterprivatebooleanfunny;}}
在structure視圖中,可以看到已經生成了getter/setter等方法:
編譯後的代碼如下:[這也是傳統java編程需要編寫的樣板代碼]
////sourcecoderecreatedfroma.classfilebyintellijidea//(poweredbyfernflowerdecompiler)//packagecom.trace;publicclasstestclass{publictestclass(){}publicstaticvoidmain(string[]args){}publicstaticclassanimal{privatestringname;privateintage;privatebooleanfunny;publicanimal(){}publicbooleanisfunny(){returnthis.funny;}publicvoidsetfunny(booleanfunny){this.funny=funny;}}publicstaticclassperson{privatestringname;privateintage;privatebooleanfriendly;publicperson(){}publicstringgetname(){returnthis.name;}publicintgetage(){returnthis.age;}publicbooleanisfriendly(){returnthis.friendly;}publicvoidsetname(stringname){this.name=name;}publicvoidsetage(intage){this.age=age;}publicvoidsetfriendly(booleanfriendly){this.friendly=friendly;}}}@tostring:作用於類,覆蓋默認的tostring()方法,可以通過of屬性限定顯示某些欄位,通過exclude屬性排除某些欄位。
@equalsandhashcode:作用於類,覆蓋默認的equals和hashcode
@nonnull:主要作用於成員變數和參數中,標識不能為空,否則拋出空指針異常。
@noargsconstructor,@requiredargsconstructor,@allargsconstructor:作用於類上,用於生成構造函數。有staticname、access等屬性。
staticname屬性一旦設定,將採用靜態方法的方式生成實例,access屬性可以限定訪問許可權。
@noargsconstructor:生成無參構造器;
@requiredargsconstructor:生成包含final和@nonnull註解的成員變數的構造器;
@allargsconstructor:生成全參構造器。
編譯後結果:
publicstaticclassperson{@nonnullprivatestringname;privateintage;privatebooleanfriendly;publicstringtostring(){return"testclass.person(name=" this.getname() ",age=" this.getage() ")";}@nonnullpublicstringgetname(){returnthis.name;}publicintgetage(){returnthis.age;}publicbooleanisfriendly(){returnthis.friendly;}publicvoidsetname(@nonnullstringname){if(name==null){thrownewnullpointerexception("name");}else{this.name=name;}}publicvoidsetage(intage){this.age=age;}publicvoidsetfriendly(booleanfriendly){this.friendly=friendly;}privateperson(){}privatestatictestclass.personof(){returnnewtestclass.person();}@constructorproperties({"name"})person(@nonnullstringname){if(name==null){thrownewnullpointerexception("name");}else{this.name=name;}}@constructorproperties({"name","age","friendly"})publicperson(@nonnullstringname,intage,booleanfriendly){if(name==null){thrownewnullpointerexception("name");}else{this.name=name;this.age=age;this.friendly=friendly;}}}@data:作用於類上,是以下註解的集合:@tostring@equalsandhashcode@getter@setter@requiredargsconstructor
@builder:作用於類上,將類轉變為建造者模式
@log:作用於類上,生成日誌變數。針對不同的日誌實現產品,有不同的註解:
其他重要註解:
@cleanup:自動關閉資源,針對實現了java.io.closeable介面的對象有效,如:典型的io流對象
編譯後結果如下:
是不是簡潔了太多。
@sneakythrows:可以對受檢異常進行捕捉並拋出,可以改寫上述的main方法如下:
@synchronized:作用於方法級別,可以替換synchronize關鍵字或lock鎖,用處不大。
作者:liwend正在掘金
② spring源碼是怎樣導出成可以被其他項目依賴的maven類型的jar包
一、導出到默認目錄 targed/dependency
從maven項目中導出項目依賴的jar包:進入工程pom.xml 所在的目錄下,執行如下命令:
1
mvn dependency:-dependencies
或在eclipse中,選擇項目的pom.xml文件,點擊右鍵菜單中的run as,見下圖紅框中,在彈出的configuration窗口中,輸入dependency:-dependencies後,點擊運行
maven項目所依賴的jar包會導出到targed/dependency目錄中。
二、導出到自定義目錄中
在maven項目下創建lib文件夾,輸入以下命令:
1
mvn dependency:-dependencies -doutputdirectory=lib
maven項目所依賴的jar包都會復制到項目目錄下的lib目錄下
三、設置依賴級別
同時可以設置依賴級別,通常使用compile級別
1
mvn dependency:-dependencies -doutputdirectory=lib -dincludescope=compile
③ 怎麼編譯運行從github上下載下來的maven項目源碼(我想調試運行的是sonarqube的源碼)跪求大神orz
maven 編譯命令
從別處拷貝來的maven項目,有時候會出現不能debug關聯的情況,即按住ctrl鍵後不能跳轉到相應的類或方法,這是需要eclipse環境生成 eclipse 項目文件的。
可以在cmd命令窗口下進入到maven項目包含pom.xml文件的目錄下,運行 mvn eclipse:eclipse 命令即可,如果還不行,可使用mvn compile :編譯源代碼 命令。
--------------------------------------------------------------------------------------------------------------------------------
下面是一些maven的常用命令:
maven2 的運行命令為 : mvn ,
常用命令為 :
mvn archetype:create :創建 maven 項目
mvn compile :編譯源代碼
mvn test-compile :編譯測試代碼
mvn test : 運行應用程序中的單元測試
mvn site : 生成項目相關信息的網站
mvn clean :清除目標目錄中的生成結果
mvn package : 依據項目生成 jar 文件
mvn install :在本地 repository 中安裝 jar
mvn eclipse:eclipse :生成 eclipse 項目文件
生成項目
建一個 java 項目 : mvn archetype:create -dgroupid=com.demo -dartifactid=app
建一個 web 項目 : mvn archetype:create -dgroupid=com.demo -dartifactid=web-app -darchetypeartifactid=maven-archetype-webapp
生成 eclipse 項目
普通 eclipse 項目執行 : mvn eclipse:eclipse
eclipse wtp 項目執行 : mvn eclipse:eclipse –dwtpversion=1.0
更詳細的,自己網路搜索 maven 編譯,學習一下吧
④ eclipse怎麼jar包源碼
每一個jar包都有對應的一個zip文件,這個zip文件需要另外進行下載。
然後在java builder path 的libraries頁,點開需要關聯源碼的jar的 號,選中source attachment,點擊edit按鈕,然後選中源碼路徑即可。
⑤ eclipse maven怎麼用
1、把下載下來的maven的zip文件隨便解壓到一個地方,比如:f: oolapache-maven-3.2.5
2、設置環境變數(雷同java_home):
新加一個"maven":
eclipse中右鍵項目->run as->maven install
maven默認會把生成的war文件、class所編譯的文件都放在項目文件夾中的target目錄下
⑥ 在ubuntu中,用mvn打包hadoop源代碼是報錯,咋回事
將hadoop源碼解壓到一個目錄,注意目錄層次不要太深,否則可能無法解壓。
進入hadoop-maven-plugins文件夾,執行 mvn install
返回源碼根目錄,執行 mvn eclipse:eclipse –dskiptests
eclipse在任意目錄創建新的workspace
eclipse設置maven:window->preference->maven->{installations...;user settings:maven\conf\settings.xml}
eclipse:file->inport->existing projects into workspace->hadoop源碼根目錄