成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

90%的Java開發(fā)人員都會(huì)犯的五個(gè)錯(cuò)誤

開發(fā) 前端
今天,我總結(jié)一些常見的編碼錯(cuò)誤,然后給出解決方案。希望大家在日常編碼中能夠避免這樣的問題。

?前言

作為一名java開發(fā)程序員,不知道大家有沒有遇到過一些匪夷所思的bug。這些錯(cuò)誤通常需要您幾個(gè)小時(shí)才能解決。當(dāng)你找到它們的時(shí)候,你可能會(huì)默默地罵自己是個(gè)傻瓜。是的,這些可笑的bug基本上都是你忽略了一些基礎(chǔ)知識(shí)造成的。其實(shí)都是很低級(jí)的錯(cuò)誤。今天,我總結(jié)一些常見的編碼錯(cuò)誤,然后給出解決方案。希望大家在日常編碼中能夠避免這樣的問題。

1. 使用Objects.equals比較對(duì)象

這種方法相信大家并不陌生,甚至很多人都經(jīng)常使用。是JDK7提供的一種方法,可以快速實(shí)現(xiàn)對(duì)象的比較,有效避免煩人的空指針檢查。但是這種方法很容易用錯(cuò),例如:

Long longValue = 123L;
System.out.println(longValue==123); //true
System.out.println(Objects.equals(longValue,123)); //false

為什么替換==為Objects.equals()?會(huì)導(dǎo)致不同的結(jié)果?這是因?yàn)槭褂?=?編譯器會(huì)得到封裝類型對(duì)應(yīng)的基本數(shù)據(jù)類型longValue,然后與這個(gè)基本數(shù)據(jù)類型進(jìn)行比較,相當(dāng)于編譯器會(huì)自動(dòng)將常量轉(zhuǎn)換為比較基本數(shù)據(jù)類型, 而不是包裝類型。

使用該Objects.equals()?方法后,編譯器默認(rèn)常量的基本數(shù)據(jù)類型為int?。下面是源碼Objects.equals()?,其中a.equals(b)?使用的是Long.equals()?會(huì)判斷對(duì)象類型,因?yàn)榫幾g器已經(jīng)認(rèn)為常量是int?類型,所以比較結(jié)果一定是false。

public static boolean equals(Object a, Object b) {
return (a == b) || (a != null && a.equals(b));
}

public boolean equals(Object obj) {
if (obj instanceof Long) {
return value == ((Long)obj).longValue();
}
return false;
}

知道了原因,解決方法就很簡(jiǎn)單了。直接聲明常量的數(shù)據(jù)類型,如Objects.equals(longValue,123L)。其實(shí)如果邏輯嚴(yán)密,就不會(huì)出現(xiàn)上面的問題。我們需要做的是保持良好的編碼習(xí)慣。

2. 日期格式錯(cuò)誤

在我們?nèi)粘5拈_發(fā)中,經(jīng)常需要對(duì)日期進(jìn)行格式化,但是很多人使用的格式不對(duì),導(dǎo)致出現(xiàn)意想不到的情況。請(qǐng)看下面的例子。

Instant instant = Instant.parse("2021-12-31T00:00:00.00Z");
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("YYYY-MM-dd HH:mm:ss")
.withZone(ZoneId.systemDefault());
System.out.println(formatter.format(instant));//2022-12-31 08:00:00

以上用于YYYY-MM-dd?格式化, 年從2021? 變成了 2022?。為什么?這是因?yàn)?nbsp;java? 的DateTimeFormatter? 模式Y(jié)YYY和yyyy?之間存在細(xì)微的差異。它們都代表一年,但是yyyy?代表日歷年,而YYYY?代表星期。這是一個(gè)細(xì)微的差異,僅會(huì)導(dǎo)致一年左右的變更問題,因此您的代碼本可以一直正常運(yùn)行,而僅在新的一年中引發(fā)問題。12月31日按周計(jì)算的年份是2022年,正確的方式應(yīng)該是使用yyyy-MM-dd格式化日期。

這個(gè)bug特別隱蔽。這在平時(shí)不會(huì)有問題。它只會(huì)在新的一年到來時(shí)觸發(fā)。我公司就因?yàn)檫@個(gè)bug造成了生產(chǎn)事故。

3. 在 ThreadPool 中使用 ThreadLocal

如果創(chuàng)建一個(gè)ThreadLocal? 變量,訪問該變量的線程將創(chuàng)建一個(gè)線程局部變量。合理使用ThreadLocal可以避免線程安全問題。

但是,如果在線程池中使用ThreadLocal ,就要小心了。您的代碼可能會(huì)產(chǎn)生意想不到的結(jié)果。舉個(gè)很簡(jiǎn)單的例子,假設(shè)我們有一個(gè)電商平臺(tái),用戶購買商品后需要發(fā)郵件確認(rèn)。

private ThreadLocal<User> currentUser = ThreadLocal.withInitial(() -> null);

private ExecutorService executorService = Executors.newFixedThreadPool(4);

public void executor() {
executorService.submit(()->{
User user = currentUser.get();
Integer userId = user.getId();
sendEmail(userId);
});
}

如果我們使用ThreadLocal?來保存用戶信息,這里就會(huì)有一個(gè)隱藏的bug。因?yàn)槭褂昧司€程池,線程是可以復(fù)用的,所以在使用ThreadLocal獲取用戶信息的時(shí)候,很可能會(huì)誤獲取到別人的信息。您可以使用會(huì)話來解決這個(gè)問題。

4. 使用HashSet去除重復(fù)數(shù)據(jù)

在編碼的時(shí)候,我們經(jīng)常會(huì)有去重的需求。一想到去重,很多人首先想到的就是用HashSet?去重。但是,不小心使用 HashSet 可能會(huì)導(dǎo)致去重失敗。

User user1 = new User();
user1.setUsername("test");

User user2 = new User();
user2.setUsername("test");

List<User> users = Arrays.asList(user1, user2);
HashSet<User> sets = new HashSet<>(users);
System.out.println(sets.size());// the size is 2

細(xì)心的讀者應(yīng)該已經(jīng)猜到失敗的原因了。HashSet?使用hashcode?對(duì)哈希表進(jìn)行尋址,使用equals?方法判斷對(duì)象是否相等。如果自定義對(duì)象沒有重寫hashcode?方法和equals方法,則默認(rèn)使用父對(duì)象的hashcode?方法和equals?方法。所以HashSet會(huì)認(rèn)為這是兩個(gè)不同的對(duì)象,所以導(dǎo)致去重失敗。

5. 線程池中的異常被吃掉

ExecutorService executorService = Executors.newFixedThreadPool(1);
executorService.submit(()->{
//do something
double result = 10/0;
});

上面的代碼模擬了一個(gè)線程池拋出異常的場(chǎng)景。我們真正的業(yè)務(wù)代碼要處理各種可能出現(xiàn)的情況,所以很有可能因?yàn)槟承┨囟ǖ脑蚨|發(fā)RuntimeException 。

但是如果沒有特殊處理,這個(gè)異常就會(huì)被線程池吃掉。這樣就會(huì)導(dǎo)出出現(xiàn)問題你都不知道,這是很嚴(yán)重的后果。因此,最好在線程池中try catch捕獲異常。

總結(jié)

本文總結(jié)了在開發(fā)過程中很容易犯的5個(gè)錯(cuò)誤,希望大家養(yǎng)成良好的編碼習(xí)慣。

責(zé)任編輯:武曉燕 來源: JAVA旭陽
相關(guān)推薦

2022-09-04 15:28:25

開發(fā)React程序員

2019-04-24 08:56:34

Java開發(fā)人員常犯錯(cuò)誤

2020-05-25 16:36:19

開發(fā)工具編碼

2022-09-12 15:51:38

JavaScrip開發(fā)編程語言

2015-03-10 10:35:41

2011-07-10 15:18:11

開發(fā)

2015-09-21 09:34:57

2020-09-23 22:40:31

Python 開發(fā)編程語言

2020-04-20 18:15:46

開發(fā)自信技術(shù)

2023-02-02 08:00:00

SQLJava開發(fā)

2023-06-12 10:51:43

開發(fā)工作效率技巧

2010-11-02 15:26:32

MVC開發(fā)工具

2020-06-09 07:57:47

前端開發(fā)代碼

2023-02-06 18:27:00

開發(fā)人員語言

2021-12-10 23:48:19

Java開發(fā)技術(shù)

2015-10-13 10:00:04

Web開發(fā)人員網(wǎng)站

2019-07-12 13:59:21

Docker軟件技術(shù)

2020-05-17 16:10:36

開發(fā)人員軟件開發(fā)開發(fā)

2023-02-21 14:51:58

JavaScrip技巧開發(fā)

2010-08-09 16:09:25

點(diǎn)贊
收藏

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

主站蜘蛛池模板: 99精品国产一区二区三区 | 99re视频精品 | 在线免费观看黄色 | 国产高清久久久 | 国产不卡一 | 色综合成人网 | 亚洲福利网 | 国产成人精品一区二区三区四区 | 成人不卡视频 | 亚洲 欧美 另类 综合 偷拍 | 国产一级免费视频 | 欧美色综合一区二区三区 | 久久99国产精一区二区三区 | 99国产精品久久久久 | 亚洲免费观看视频 | 国产传媒视频在线观看 | 国产精品18久久久久久白浆动漫 | 日韩a v在线免费观看 | 狠狠干天天干 | 中文字幕不卡视频在线观看 | 一级黄色片免费在线观看 | av无遮挡 | 99亚洲精品 | 九色网址 | 一区二区视频在线 | 99精品欧美一区二区三区综合在线 | 黄色一级视频免费 | 国产高清视频在线观看 | 久久久精品影院 | 色综合一区 | 欧美一级久久 | 国产在线一区二区三区 | 免费av手机在线观看 | 91视频网址 | 日日噜噜噜夜夜爽爽狠狠视频, | 欧美黑人一区二区三区 | 亚洲电影中文字幕 | 欧美精品影院 | 亚洲有码转帖 | 成人综合视频在线 | 亚洲一区二区三区在线 |