自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

在Java中,整數(shù)的絕對值竟然不一定是正數(shù)?。?!

開發(fā) 后端
絕對值是指一個(gè)數(shù)在數(shù)軸上所對應(yīng)點(diǎn)到原點(diǎn)的距離,所以,在數(shù)學(xué)領(lǐng)域,正數(shù)的絕對值是這個(gè)數(shù)本身,負(fù)數(shù)的絕對值應(yīng)該是他的相反數(shù)

絕對值是指一個(gè)數(shù)在數(shù)軸上所對應(yīng)點(diǎn)到原點(diǎn)的距離,所以,在數(shù)學(xué)領(lǐng)域,正數(shù)的絕對值是這個(gè)數(shù)本身,負(fù)數(shù)的絕對值應(yīng)該是他的相反數(shù)。

這幾乎是每個(gè)人都知道的。

在Java中,想要獲得有個(gè)數(shù)字的絕對值,可以使用java.lang.Math中的abs方法,這個(gè)類共有4個(gè)重載的abs方法,分別是: 

  1. public static int abs(int a) {  
  2.        return (a < 0) ? -a : a;  
  3.    }  
  4.    public static long abs(long a) {  
  5.        return (a < 0) ? -a : a;  
  6.    }  
  7.    public static float abs(float a) {  
  8.        return (a <= 0.0F) ? 0.0F - a : a;  
  9.    }  
  10.    public static double abs(double a) {  
  11.        return (a <= 0.0D) ? 0.0D - a : a;  
  12.    } 

以上4個(gè)方法分別返回int、long、float、double類型的絕對值,方法里面的邏輯也簡單,無非就是整數(shù)直接返回,負(fù)數(shù)取相反數(shù)返回。

所以,基于以上所有的知識,我們經(jīng)常會(huì)直接使用Math.abs來對一個(gè)數(shù)字取絕對值。

在我們的代碼中,也有很多這樣的例子。

比如,我們需要用訂單號做分庫分表,但是訂單號是字符串類型,所以,我們就需要取得這個(gè)字符換的hashCode,因?yàn)閔ashCode可能是負(fù)數(shù),所以然后再對hashCode取絕對值,再用這個(gè)值去對分表數(shù)取模:

  1. Math.abs(orderId.hashCode()) % 1024; 

但是,上面這個(gè)邏輯是有問題的?。?!

因?yàn)樵跇O特殊情況下,上面的代碼會(huì)得到一個(gè)負(fù)數(shù)的值。

這個(gè)極特殊情況下就是當(dāng)hashCode是Integer.MIN_VALUE,即整數(shù)能表達(dá)的最小值的時(shí)候,可以代碼驗(yàn)證下: 

  1. public static void main(String[] args) {  
  2.     System.out.println(Math.abs(Integer.MIN_VALUE));  

執(zhí)行以上代碼,得到的結(jié)果是: 

  1. -2147483648 

很明顯,這是個(gè)負(fù)數(shù)?。?!

為什么會(huì)這樣呢?

這要從Integer的取值范圍說起,int的取值范圍是-2^31 —— (2^31) - 1,即-2147483648 至 2147483647

那么,當(dāng)我們使用abs取絕對值時(shí)候,想要取得-2147483648的絕對值,那應(yīng)該是2147483648。

但是,2147483648大于了2147483647,即超過了int的取值范圍。這時(shí)候就會(huì)發(fā)生越界。

2147483647用二進(jìn)制的補(bǔ)碼表示是:

01111111 11111111 11111111 11111111 

這個(gè)數(shù) +1 得到:

10000000 00000000 00000000 00000000 

這個(gè)二進(jìn)制就是-2147483648的補(bǔ)碼。

雖然,這種情況發(fā)生的概率很低,只有當(dāng)要取絕對值的數(shù)字是-2147483648的時(shí)候,得到的數(shù)字還是個(gè)負(fù)數(shù)。

那么,如何解決這個(gè)問題呢?

既然是以為越界了導(dǎo)致最終結(jié)果變成負(fù)數(shù),那就解決越界的問題就行了,那就是在取絕對值之前,把這個(gè)int類型轉(zhuǎn)成long類型,這樣就不會(huì)出現(xiàn)越界了。

如,前面我們的分表邏輯修改為

  1. Math.abs((long)orderId.hashCode()) % 1024;  

就萬無一失了。

大家可以執(zhí)行下以下代碼: 

  1. public static void main(String[] args) {  
  2.       System.out.println(Math.abs((long)Integer.MIN_VALUE));  
  3.   } 

得到的結(jié)果就是:

  1. 2147483648 

以上,就是今天要介紹的知識點(diǎn)了。

但是,一定要記得,對long類型取絕對值其實(shí)也可能存在這個(gè)情況哦!只不過發(fā)生的概率就更低了,但是只要他存在,就有可能發(fā)生哦! 

 

責(zé)任編輯:龐桂玉 來源: Hollis
相關(guān)推薦

2009-11-25 09:20:31

Windows 7網(wǎng)絡(luò)掉線

2024-07-22 08:15:30

2021-06-18 10:29:17

物聯(lián)網(wǎng)安全互聯(lián)網(wǎng)IoT

2021-01-19 21:45:09

PHP語言開發(fā)

2019-08-19 07:54:20

2020-08-30 14:31:40

Python編程語言開發(fā)

2025-03-12 06:55:00

2016-10-17 18:00:46

WIFIWIFI信號

2021-02-26 09:04:22

數(shù)組ArrayListHashMap

2022-03-21 09:47:02

深度學(xué)習(xí)模型人工智能

2018-05-15 16:01:53

對象內(nèi)存JVM

2022-08-15 13:59:10

XaaS云計(jì)算

2013-05-14 10:41:16

Palo AltoNGFWUTM

2010-11-17 11:11:44

跳槽

2021-01-29 09:17:00

深度學(xué)習(xí)AI人工智能

2018-01-18 05:20:59

2021-05-07 20:08:52

人工智能AI游戲

2016-11-28 11:19:48

術(shù)語神秘

2022-12-26 09:16:45

Guava架構(gòu)模型

2021-05-08 16:33:14

人工智能游戲機(jī)器學(xué)習(xí)
點(diǎn)贊
收藏

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