溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

java中long(Long)與int(Integer)之間的轉換方式

發布時間:2020-10-13 22:37:31 來源:腳本之家 閱讀:276 作者:六月星海 欄目:開發技術

我就廢話不多說了,大家還是直接看代碼吧~

public static void main(String[] args) {
 // 1、將long型轉化為int型,其中int、long是基礎類型
 long a = 10;
 int b = (int) a;
 System.out.println("1、將long型轉化為int型:" + b);
 
 // 2、將int型轉化為long型,其中int、long都是基礎類型
 int a1 = 10;
 long b1 = a1;
 System.out.println("2、將int型轉化為long型:" + b1);
 
 // 3、將Long型轉換為int型的,其中Long型是包裝類型
 Long a2 = 10l;
 int b2 = a2.intValue();
 System.out.println("3、將Long型轉換為int型:" + b2);
 
 //4、將Integer型轉化為long型,其中Integer型是包裝類型,long型是基礎類型
 Integer a3=10;
 long b3=a3.longValue();
 System.out.println("4、將Integer型轉化為long型:"+b3);
 
 //5、將Integer型轉化為Long型,其中Integer、Long型都是包裝類型
 Integer a4=10;
 Long b4=a4.longValue();
 System.out.println("5、將Integer型轉化為Long型:"+b4);
 }

輸出結果:

1、將long型轉化為int型:10

2、將int型轉化為long型:10

3、將Long型轉換為int型:10

4、將Integer型轉化為long型:10

5、將Integer型轉化為Long型:10

補充知識:JAVA中Long與Integer比較容易犯的錯誤

今天使用findbugs掃描項目后發現很多高危漏洞,其中非常常見的一個是比較兩個Long或Integer時直接使用的==來比較。 其實這樣是錯誤的。

因為Long與Ineger都是包裝類型,是對象。 而不是普通類型long與int , 所以它們在比較時必須都應該用equals,或者先使用longValue()或intValue()方法來得到他們的基本類型的值然后使用==比較也是可以的。

但是有一種特殊情況, 其實Long與Integer都將 -128~127 這些對象緩存了。 可以看看Long類型源碼里面有一個LongCache類,代碼如下:

private static class LongCache {
 private LongCache(){}
 
 static final Long cache[] = new Long[-(-128) + 127 + 1];
 
 static {
   for(int i = 0; i < cache.length; i++)
 cache[i] = new Long(i - 128);
 }
  }

先看看這個例子:

public class Test05 {
 
  public static void main(String[] args) {
    Long a = 5L;
    Long b = 5L;
 
    System.out.println("a == b ? " + (a == b));
 
    Long c = 129L;
    Long d = 129L;
    System.out.println("c == d ? " + (c == d));
  }
}

打印的結果是:

a == b ? true

c == d ? false

原因

首先來看看 Long a = 5L ; 它是如何將一個基本類型long包裝成一個對象Long的 。

可以寫一個測試類,然后反編譯一下,看看java它是如何解析Long a = 5L這樣一條命令的 。

測試類如下:

public class Test06 {
  Long l = 3L;
}

然后使用javap -verbose Test06 就能看到反編譯的結果了, 下面是輸出的部分:

{
java.lang.Long l;
 
public com.spring.test.Test06();
 Code:
  Stack=3, Locals=1, Args_size=1
  0:  aload_0
  1:  invokespecial  #10; //Method java/lang/Object."<init>":()V
  4:  aload_0
  5:  ldc2_w #12; //long 3l
  8:  invokestatic  #14; //Method java/lang/Long.valueOf:(J)Ljava/lang/Long;
  11: putfield    #20; //Field l:Ljava/lang/Long;
  14: return
 LineNumberTable:
  line 3: 0
  line 5: 4
  line 3: 14
 
 LocalVariableTable:
  Start Length Slot Name  Signature
  0   15   0  this    Lcom/spring/test/Test06; 
 
}

從Code中的8可以看出調用了Long的一個類方法Long.valueOf(Long) , 所以可以得到的結論是Long a = 5L實際上等于 Long a = Long.valueOf(5) ;

然后再看看Long.valueOf()方法是如何定義的:

public static Long valueOf(long l) {
 final int offset = 128;
 if (l >= -128 && l <= 127) { // will cache
   return LongCache.cache[(int)l + offset];
 }
    return new Long(l);
  }

一目了然,會先判斷基本類型的值如果在-128~127之間,就會直接從LongCache里面取出緩存的對象返回,否則就new一個新的Long對象返回 。

現在就不難理解Test05程序執行得到的結果了,因為a與b等于5,在-127~128之內,所以都是直接從LongCache里面返回的一個Long對象,所以他們在使用==比較的時候,就是相等的(對于對象類型來說,==比較的是兩個對象的引用指向堆中的地址) ,而c與d等于129,不在-127~128之間,所以他們他們是分別new出來的兩個新的Long對象,使用==來比較自然是不相等的了。

Long重寫了equals方法:

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

它是先通過.longValue()方法獲取Long對象的基本類型long的值之后再做比較的。

所以對于Integer與Long的比較,最好是使用equals來比較才能確保得到我們想要的結果。

Integer與Long一樣,這里就不舉例了。

以上這篇java中long(Long)與int(Integer)之間的轉換方式就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女