有時候我們?yōu)榱私y(tǒng)一管理會把一些變量放到 yml 配置文件中
例如
![f5aed240-bb44-11ec-aa7f-dac502259ad0.png](https://file1.elecfans.com//web2/M00/94/E4/wKgZomTl_R6ALT4zAACRblKLCaw022.png)
使用方法
定義對應字段的實體
@Data // 指定前綴 @ConfigurationProperties(prefix = "developer") @Component public class DeveloperProperty { privateStringname; privateStringwebsite; privateStringqq; privateStringphoneNumber; }
@Data
// 指定前綴
@ConfigurationProperties(prefix = "developer")
@Component
public class DeveloperProperty {
privateStringname;
privateStringwebsite;
privateStringqq;
privateStringphoneNumber;
}
使用時注入這個bean
@RestController
@RequiredArgsConstructor
public class PropertyController {
finalDeveloperPropertydeveloperProperty;
@GetMapping("/property")
publicObjectindex() {
returndeveloperProperty.getName();
}
}
2、用@RequiredArgsConstructor代替@Autowired
我們都知道注入一個 bean 有三種方式哦(set 注入, 構造器注入, 注解注入),Spring 推薦我們使用構造器的方式注入 Bean
我們來看看上段代碼編譯完之后的樣子
![f5bec718-bb44-11ec-aa7f-dac502259ad0.png](https://file1.elecfans.com//web2/M00/94/E4/wKgZomTl_R6AVTEXAAGQsnpj0xk479.png)
RequiredArgsConstructor:lombok提供
3、代碼模塊化
阿里巴巴 Java 開發(fā)手冊中說到每個方法的代碼不要超過 50 行(我沒記錯的話),在實際的開發(fā)中我們要善于拆分自己的接口或方法, 做到一個方法只處理一種邏輯, 說不定以后某個功能就用到了, 拿來即用。
![f5cbc5e4-bb44-11ec-aa7f-dac502259ad0.png](https://file1.elecfans.com//web2/M00/94/E4/wKgZomTl_R6Abo3FAAI8SPE4NVU082.png)
4、拋異常而不是返回
在寫業(yè)務代碼的時候,經(jīng)常會根據(jù)不同的結果返回不同的信息,盡量減少返回,會顯得代碼比較亂
反例
![f5ea7660-bb44-11ec-aa7f-dac502259ad0.png](https://file1.elecfans.com//web2/M00/94/E4/wKgZomTl_R6AGIYrAAMWArENHuE092.png)
正例
![f5f9d7ae-bb44-11ec-aa7f-dac502259ad0.png](https://file1.elecfans.com//web2/M00/94/E4/wKgZomTl_R-AV3hjAAFdrcUgcCA825.png)
5、減少不必要的db
盡可能的減少對數(shù)據(jù)庫的查詢
舉例子
刪除一個服務(已下架或未上架的才能刪除),之前有看別人寫的代碼,會先根據(jù)id查詢該記錄,然后做一些判斷
反例
![f60b0efc-bb44-11ec-aa7f-dac502259ad0.png](https://file1.elecfans.com//web2/M00/94/E4/wKgZomTl_R-AIuabAAFhuP9Ho5Y675.png)
正例
![f618673c-bb44-11ec-aa7f-dac502259ad0.png](https://file1.elecfans.com//web2/M00/94/E4/wKgZomTl_R-AdhmgAAEkh1NKlnk193.png)
6、不要返回 null
反例
![f627fa58-bb44-11ec-aa7f-dac502259ad0.png](https://file1.elecfans.com//web2/M00/94/E4/wKgZomTl_R-Ae6_eAAEnOdpXgio547.png)
正例
![f645107a-bb44-11ec-aa7f-dac502259ad0.png](https://file1.elecfans.com//web2/M00/94/E4/wKgZomTl_R-AcJ1AAAFeT7WGAhI142.png)
別處調(diào)用方法時,避免不必要的空指針
7、if else
不要太多了if else if,可以試試策略模式代替
8、減少controller業(yè)務代碼
業(yè)務代碼盡量放到service層進行處理,后期維護起來也好操作而且美觀
反例
![f656205e-bb44-11ec-aa7f-dac502259ad0.png](https://file1.elecfans.com//web2/M00/94/E4/wKgZomTl_SCANeMDAANYQ93YwcU160.png)
正例
![f664f05c-bb44-11ec-aa7f-dac502259ad0.png](https://file1.elecfans.com//web2/M00/94/E4/wKgZomTl_SCADtYUAAOOyfp6w1U595.png)
9、利用好Idea
目前為止市面上的企業(yè)基本都用idea作為開發(fā)工具了吧
舉一個小例子
idea會對我們的代碼進行判斷,提出合理的建議
例如:
![f676f018-bb44-11ec-aa7f-dac502259ad0.png](https://file1.elecfans.com//web2/M00/94/E4/wKgZomTl_SCAZnOZAAEcjcUcJcM637.png)
它推薦我們用lanbda的形式代替,點擊replace
![f683d882-bb44-11ec-aa7f-dac502259ad0.png](https://file1.elecfans.com//web2/M00/94/E4/wKgZomTl_SCAQPCMAADbVdRsIU0426.png)
10、閱讀源碼
一定要養(yǎng)成閱讀源碼的好習慣包括優(yōu)秀的開源項目GitHub上stars:>1000, 會從中學好好多知識包括其對代碼的設計思想以及高級API,面試加分(好多面試官習慣問源碼相關的知識)
11、設計模式
23種設計模式,要嘗試代碼中運用設計模式思想,寫出的代碼即規(guī)范又美觀還高大上哈哈。
12、擁抱新知識
像我們這種工作年限少的程序員,我覺得要多學習自己認知之外的知識,不能每天crud,有機會就多用用有點難度的知識,沒有機會(項目較傳統(tǒng)),可以自己下班多些相關demo練習
13、基礎問題
map遍歷
HashMap<String, String> map = newHashMap<>();
map.put("name", "du");
for(Stringkey : map.keySet()) {
Stringvalue = map.get(key);
}
map.forEach((k, v) -> {
});
// 推薦
for(Map.Entry<String, String> entry : map.entrySet()) {
}
optional 判空
//獲取子目錄列表
publicList getChild(String pid) {
if(V.isEmpty(pid)) {
pid = BasicDic.TEMPORARY_DIRECTORY_ROOT;
}
CatalogueTreeNode node = treeNodeMap.get(pid);
returnOptional.ofNullable(node)
.map(CatalogueTreeNode::getChild)
.orElse(Collections.emptyList());
}
遞歸
大數(shù)據(jù)量的遞歸時,避免在遞歸方法里new對象,可以試試把對象當作方法參數(shù)進行傳遞使用
注釋
類 接口方法 注解 較復雜的方法 注釋都要寫而且要寫清楚, 有時候寫注釋不是給別人看的 而是給自己看的
14、判斷元素是否存在
hashSet 而不是 list,list 判斷一個元素是否存在的代碼
ArrayList list= newArrayList<>();
// 判斷a是否在list中
for(inti = 0; i < list.size(); i++)
if("a".equals(elementData[i]))
returni;
由此可見其復雜度為On,而hashSet底層采用hashMap作為數(shù)據(jù)結構進行存儲,元素都放到map的key(即鏈表中)
HashSet set= newHashSet<>();
// 判斷a是否在set中
intindex = hash(a);
returngetNode(index) != null
由此可見其復雜度為O1。
-
JAVA
+關注
關注
19文章
2977瀏覽量
105227 -
代碼
+關注
關注
30文章
4838瀏覽量
69141
原文標題:14 個寫 Java 的習慣
文章出處:【微信號:AndroidPush,微信公眾號:Android編程精選】歡迎添加關注!文章轉載請注明出處。
發(fā)布評論請先 登錄
相關推薦
評論