14 個(gè)寫(xiě) Java 的習(xí)慣

有時(shí)候我們?yōu)榱私y(tǒng)一管理會(huì)把一些變量放到 yml 配置文件中
例如

使用方法
定義對(duì)應(yīng)字段的實(shí)體
@Data
// 指定前綴
@ConfigurationProperties(prefix =?"developer")
@Component
public class DeveloperProperty {
????private?String?name;
????private?String?website;
????private?String?qq;
????private?String?phoneNumber;
}
@Data
// 指定前綴
@ConfigurationProperties(prefix =?"developer")
@Component
public class DeveloperProperty {
????private?String?name;
????private?String?website;
????private?String?qq;
????private?String?phoneNumber;
}使用時(shí)注入這個(gè)bean
@RestController
@RequiredArgsConstructor
public class PropertyController {
?
????final?DeveloperProperty?developerProperty;
?
????@GetMapping("/property")
????public?Object?index() {
???????return?developerProperty.getName();
????}
}2. 用@RequiredArgsConstructor代替@Autowired
我們都知道注入一個(gè) bean 有三種方式哦(set 注入, 構(gòu)造器注入, 注解注入),Spring 推薦我們使用構(gòu)造器的方式注入 Bean
我們來(lái)看看上段代碼編譯完之后的樣子

RequiredArgsConstructor:lombok提供
3.代碼模塊化
阿里巴巴 Java 開(kāi)發(fā)手冊(cè)中說(shuō)到每個(gè)方法的代碼不要超過(guò) 50 行(我沒(méi)記錯(cuò)的話(huà)),在實(shí)際的開(kāi)發(fā)中我們要善于拆分自己的接口或方法, 做到一個(gè)方法只處理一種邏輯, 說(shuō)不定以后某個(gè)功能就用到了, 拿來(lái)即用。

4. 拋異常而不是返回
在寫(xiě)業(yè)務(wù)代碼的時(shí)候,經(jīng)常會(huì)根據(jù)不同的結(jié)果返回不同的信息,盡量減少返回,會(huì)顯得代碼比較亂
反例

正例

5. 減少不必要的db
盡可能的減少對(duì)數(shù)據(jù)庫(kù)的查詢(xún)
舉例子
刪除一個(gè)服務(wù)(已下架或未上架的才能刪除),之前有看別人寫(xiě)的代碼,會(huì)先根據(jù)id查詢(xún)?cè)撚涗洠缓笞鲆恍┡袛?/span>
反例

正例

6. 不要返回 null
反例

正例

別處調(diào)用方法時(shí),避免不必要的空指針
7. if else
不要太多了if else if,可以試試策略模式代替
8. 減少controller業(yè)務(wù)代碼
業(yè)務(wù)代碼盡量放到service層進(jìn)行處理,后期維護(hù)起來(lái)也好操作而且美觀(guān)
反例

正例

9. 利用好Idea
目前為止市面上的企業(yè)基本都用idea作為開(kāi)發(fā)工具了吧
舉一個(gè)小例子
idea會(huì)對(duì)我們的代碼進(jìn)行判斷,提出合理的建議
例如:

它推薦我們用lanbda的形式代替,點(diǎn)擊replace

10. 閱讀源碼
一定要養(yǎng)成閱讀源碼的好習(xí)慣包括優(yōu)秀的開(kāi)源項(xiàng)目GitHub上stars:>1000, 會(huì)從中學(xué)好好多知識(shí)包括其對(duì)代碼的設(shè)計(jì)思想以及高級(jí)API,面試加分(好多面試官習(xí)慣問(wèn)源碼相關(guān)的知識(shí))
11. 設(shè)計(jì)模式
23種設(shè)計(jì)模式,要嘗試代碼中運(yùn)用設(shè)計(jì)模式思想,寫(xiě)出的代碼即規(guī)范又美觀(guān)還高大上哈哈。
12. 擁抱新知識(shí)
像我們這種工作年限少的程序員,我覺(jué)得要多學(xué)習(xí)自己認(rèn)知之外的知識(shí),不能每天crud,有機(jī)會(huì)就多用用有點(diǎn)難度的知識(shí),沒(méi)有機(jī)會(huì)(項(xiàng)目較傳統(tǒng)),可以自己下班多些相關(guān)demo練習(xí)
13. 基礎(chǔ)問(wèn)題
HashMap<String,?String> map =?new?HashMap<>();
????????map.put("name",?"du");
????????for?(String?key : map.keySet()) {
????????????String?value = map.get(key);
????????}
?
????????map.forEach((k, v) -> {
?
????????});
?
????????// 推薦
????????for?(Map.Entry<String,?String> entry : map.entrySet()) {
?
????????}//獲取子目錄列表
public?List getChild(String pid) {
????????????if?(V.isEmpty(pid)) {
????????????pid = BasicDic.TEMPORARY_DIRECTORY_ROOT;
????????}
????????CatalogueTreeNode node = treeNodeMap.get(pid);
?
????????return?Optional.ofNullable(node)
????????????????.map(CatalogueTreeNode::getChild)
????????????????.orElse(Collections.emptyList());
????} 遞歸
大數(shù)據(jù)量的遞歸時(shí),避免在遞歸方法里new對(duì)象,可以試試把對(duì)象當(dāng)作方法參數(shù)進(jìn)行傳遞使用
注釋
類(lèi) 接口方法 注解 較復(fù)雜的方法 注釋都要寫(xiě)而且要寫(xiě)清楚, 有時(shí)候?qū)懽⑨尣皇墙o別人看的 而是給自己看的
14. 判斷元素是否存在
hashSet 而不是 list,list 判斷一個(gè)元素是否存在的代碼
ArrayList?list?=?new?ArrayList<>();
?
// 判斷a是否在list中
?
for?(int?i =?0; i list.size(); i++)
???????if?("a".equals(elementData[i]))
??????????return?i; 由此可見(jiàn)其復(fù)雜度為On,而hashSet底層采用hashMap作為數(shù)據(jù)結(jié)構(gòu)進(jìn)行存儲(chǔ),元素都放到map的key(即鏈表中)
HashSet?set?=?new?HashSet<>();
?
// 判斷a是否在set中
?
int?index = hash(a);
?
return?getNode(index) !=?null 由此可見(jiàn)其復(fù)雜度為O1。
地址:https://blog.csdn.net/weixin_44912855/article/details/1208661942022年粉絲福利? http://download.java1234.com/ 每月送?666?套Java海量資源網(wǎng)站?VIP會(huì)員,供大伙一起學(xué)Java 如果沒(méi)過(guò)鋒哥微信的 加一下鋒哥微信備注?VIP?即可開(kāi)通
?你在看嗎
