基本上每個程式設計師都會寫程式碼,但寫程式碼的速度不盡相同。
為什麼有些人,一天只能寫幾百行程式碼?
而有些人,一天可以寫幾千行程式碼?
有沒有辦法,可以提升開發效率,在相同的時間內,寫出更多的程式碼呢?
今天我跟大家一起聊聊在idea
中,能提升編碼效率的12
種外掛,希望對大家有所幫助。
之前對lombok還有爭議,到底該不該在專案中使用,為此我還專門寫了一篇文章《迷茫了,我們該不該用lombok?》。
現在新版的idea已經內建了lombok外掛,所以用它是一種趨勢。
我之所以把lombok放在整篇文章的第一個介紹,是因為它真的可以幫我少寫很多程式碼,特別是entity、DTO、VO、BO中的。
我們用User類舉例,以前定義javabean需要寫如下程式碼:
public class User {
private Long id;
private String name;
private Integer age;
private String address;
public User() {
}
public User(Long id, String name, Integer age, String address) {
this.id = id;
this.name = name;
this.age = age;
this.address = address;
}
public Long getId() {
return id;
}
public String getName() {
return name;
}
public Integer getAge() {
return age;
}
public String getAddress() {
return address;
}
public void setId(Long id) {
this.id = id;
}
public void setName(String name) {
this.name = name;
}
public void setAge(Integer age) {
this.age = age;
}
public void setAddress(String address) {
this.address = address;
}
@Override
public boolean equals(Object o) {
if (this == o) returntrue;
if (o == null || getClass() != o.getClass()) returnfalse;
User user = (User) o;
return Objects.equals(id, user.id) &&
Objects.equals(name, user.name) &&
Objects.equals(age, user.age) &&
Objects.equals(address, user.address);
}
@Override
public int hashCode() {
return Objects.hash(id, name, age, address);
}
@Override
public String toString() {
return"User{" +
"id=" + id +
", name='" + name + '\'' +
", age=" + age +
", address='" + address + '\'' +
'}';
}
}
該User類中包含了:成員變數、getter/setter方法、構造方法、equals、hashCode方法。
咋一看,程式碼還是挺多的。而且還有個問題,如果User類中的程式碼修改了,比如:age欄位改成字串型別,或者name欄位名稱修改了,是不是需要同步修改相關的成員變數、getter/setter方法、構造方法、equals、hashCode方法全都修改一遍?
好訊息是用lombok可以解決這個問題。
如果是idea2020.3之前的版本,需要在idea中安裝如下外掛:
但idea2020.3之後,idea已經內建了lombok的功能。
有了lombok外掛,現在我們在idea只用這樣寫程式碼,就能實現上面的功能了:
@ToString
@EqualsAndHashCode
@NoArgsConstructor
@AllArgsConstructor
@Getter
@Setter
public class User {
private Long id;
private String name;
private Integer age;
private String address;
}
簡直太輕鬆了,真的可以少寫很多程式碼。
此外,我們還需要在專案的pom檔案中,引入lombok的依賴包,不然專案會跑不起來。
在國內mybatis
已經成為了最主流的資料庫框架了,該框架屬於半自動化的ORM持久化框架,相對於hibernate這種全自動化的持久化框架更靈活,效能更高。
在mybatis
中,我們需要自己定義mapper和對應的xml檔案完成繫結。
在這裡我們以使用者表為例,首先需要定義UserMapper介面:
public interface UserMapper {
int insertUser(UserModel user);
}
然後需要UserMapper.xml組態檔:
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.sue.jump.mappers.UserMapper">
<sql id="selectUserVo">
id, name, age, sex
</sql>
<insert id="insertUser" parameterType="com.sue.jump.model.UserModel">
INSERT INTO user
<trim prefix="(" suffix=")" suffixOverrides=",">
<if test="id != null ">
id,
</if>
<if test="name != null and name != ''">
name,
</if>
<if test="age != null ">
age,
</if>
<if test="sex != null ">
sex,
</if>
</trim>
<trim prefix="values (" suffix=")" suffixOverrides=",">
<if test="id != null ">
#{id},
</if>
<if test="name != null and name != ''">
#{name},
</if>
<if test="age != null ">
#{age},
</if>
<if test="sex != null ">
#{sex},
</if>
</trim>
</insert>
</mapper>
UserMapper.xml檔案中,mapper標籤的namespace對應UserMapper介面名,而insert標籤的id=insertUser,正好對應UserMapper介面中的insertUser方法。
那麼,在專案中如何通過UserMapper類中的getUser方法,能夠快速存取UserMapper.xml檔案中的getUser方法?
答:這就需要使用Free Mybatis plugin
外掛了。
安裝了該外掛之後,在UserMapper介面的介面名和方法名的左邊,會多了兩個綠色的箭頭,我們點選該箭頭,就能跳轉到UserMapper.xml檔案對應的mapper標籤或者insertUser語句上。
此外,在UserMapper.xml檔案的insertUser語句的左邊,也會多出一個綠色的箭頭,我們點選該箭頭,也能跳轉到UserMapper介面的insertUser方法上。
有了這個外掛,我們就能在mapper和xml之間自由切換,自由玩耍了,再也不用像以前那樣搜尋來搜尋去。
有些小夥伴,包括我自己可能英語不太好(我英語剛過四級)。
我們在給變數或者方法取名時,要想半天。特別是在閱讀JDK英文檔案時,遇到了一些生僻字,簡直頭大。
有個好訊息是使用:Translation
外掛,能夠讓我們在檔案中自由飛翔。
安裝完Translation
外掛之後,在other settings中多了一個Translation選單。
點選該選單:
在右邊的視窗中,可以選擇翻譯軟體。
選中需要翻譯的英文檔案:
在右鍵彈窗的視窗中,選擇Translation選項,會彈如下視窗:
一段英文段落,一下子翻譯成了中文,簡直太爽了。
如果你是從事Java開發工作的小夥伴,肯定看過阿里巴巴的《Java開發手冊》。
該手冊總結了我們在日常開發過程中,可能會遇到的問題。從程式設計規約、異常紀錄檔、單位測試、安全規約、Mysql資料庫和工程結構,這6大方面,規範了開發的流程,確保我們能寫出高效、優雅的程式碼。
但這些規範性的東西,僅僅靠人的自覺性,很難達到預期的效果。
為了解決這個問題,阿里巴巴推出了Alibaba Java Coding Guidelines
外掛,能夠通過該外掛,直接查出不合規範的程式碼。
安裝了該外掛之後,按下快捷鍵:Ctrl+Alt+Shift+J
,可以可對整個專案或單個檔案進行編碼規約掃描。
掃描後會將不規範的程式碼按從高到低。
目前有三個等級顯示在下方:
點選左邊其中一個不規範的程式碼行,右邊視窗會立刻顯示不規範的詳細程式碼,便於我們快速定位問題。
nice。
很多時候,我們需要給某個物件賦值,如果引數比較多的話,需要手寫大量的setter
或者getter
程式碼。
有沒有辦法一鍵搞定呢?
答:有,使用GenerateAllSetter
外掛。
安裝完外掛之後,在建立的物件上,按快捷鍵下:alt + enter
。
在彈出的視窗中選擇:Generate all setter with default value。
就會自動生成如下程式碼:
簡直太方便了。
我們平時在閱讀原始碼時,為了梳理清楚內部邏輯,經常需要畫一些時序圖
。
如果我們直接畫,會浪費很多時間,而且畫的圖不一定正確。
這時可以使用:SequenceDiagram
外掛。
選擇具體某個方法,右鍵選擇:sequence diagram選項:
之後,會出現時序圖:
從此以後,能夠成為畫圖高手了,完美。
在程式碼格式方面,有許多地方,需要我們注意,比如:無用匯入、沒寫註釋、語法錯誤、方法太長等等。
有沒有辦法,可以在idea中,一次性檢測出上面的這些問題呢?
答:使用CheckStyle-IDEA
外掛。
CheckStyle-IDEA
是一個檢測程式碼格式是否滿足規範的工具,其中用得比較多的是Google
規範和Sun
規範。
安裝完外掛後,在idea的下方會出現:CheckStyle選項:
點選左邊的綠色按鈕,可以掃描程式碼。在中間位置,會顯示不符合程式碼規範的原因。
雙擊程式碼,即可直接跳轉到具體程式碼:
在idea中開發Java專案,有個很不爽的地方是:每次修改一個類或者介面,都需要重啟服務,否則不會執行最新地方。
而每次重啟,都需要花大量的時間。
有沒有辦法,Java程式碼修改後不用重啟系統,立即生效呢?
答:使用JRebel and XRebel
外掛。
如圖:
安裝完成之後,這裡會有兩個綠色的按鈕,並且在右邊多了一個選項Select Rebel Agents:
其中一個綠色的按鈕,表示熱部署啟動專案,另外一個表示用debug預設熱部署啟動專案。
Select Rebel Agents選項中包含三個值:
說實話,idea現有的程式碼提示功能,已經很強大了。
但如果你使用過Codota
外掛,它會讓你寫程式碼的速度更上一層樓。
安裝完外掛之後,我們在寫程式碼時,它會給你一些提示:
這些提示是基於ai統計出來的,非常有參考價值。
很多時候,我需要把json
中的引數,轉換成實體物件
中的引數。或者把實體物件
中的引數,轉換成json
中的引數。
以前我們都是手動一個變數,一個變數的拷貝的。
但現在有個好訊息是,idea的GsonFormat
外掛可以幫我們完成這件事。
安裝完外掛之後,先建立一個空類:
按下快捷鍵:alt + s
,會彈出下面這個視窗:
然後在該視窗中,錄入json資料。
點選確定按鈕,就會自動生成這些程式碼:
簡直帥呆了。
我們平時寫程式碼的時候,括號是讓我們非常頭疼的地方,特別是程式碼邏輯很多,層層巢狀的情況。
一眼很難看出,程式碼是從哪個括號開始,到哪個反括號結束的。
有沒有辦法解決這個問題呢?
答:使用Rainbow Brackets
外掛。
安裝完外掛之後,括號和反括號,在程式碼中會自動按照不同顏色做區分:
非常顯目,非常直觀。
有些時候,我們閱讀的程式碼很多,比如某個類中包含的方法和成員變數很多。
從上往下,一點點往下翻,會浪費很多時間。那麼有沒有辦法,能夠快速翻到想看的程式碼呢?
答:有,可以使用CodeGlance
外掛。
安裝完外掛之後,在程式碼右側,會出現下面這個視窗:
它是程式碼的縮圖,通過它我們能夠非常快速的切換程式碼塊。
如果這篇文章對您有所幫助,或者有所啟發的話,幫忙掃描下發二維條碼關注一下,您的支援是我堅持寫作最大的動力。
求一鍵三連:點贊、轉發、在看。
關注公眾號:【蘇三說技術】,在公眾號中回覆:面試、程式碼神器、開發手冊、時間管理有超讚的粉絲福利,另外回覆:加群,可以跟很多BAT大廠的前輩交流和學習。