java中l(wèi)ong(Long)與int(Integer)之間的轉(zhuǎn)換方式
我就廢話不多說了,大家還是直接看代碼吧~
public static void main(String[] args) { // 1、將long型轉(zhuǎn)化為int型,其中int、long是基礎(chǔ)類型 long a = 10; int b = (int) a; System.out.println("1、將long型轉(zhuǎn)化為int型:" + b); // 2、將int型轉(zhuǎn)化為long型,其中int、long都是基礎(chǔ)類型 int a1 = 10; long b1 = a1; System.out.println("2、將int型轉(zhuǎn)化為long型:" + b1); // 3、將Long型轉(zhuǎn)換為int型的,其中Long型是包裝類型 Long a2 = 10l; int b2 = a2.intValue(); System.out.println("3、將Long型轉(zhuǎn)換為int型:" + b2); //4、將Integer型轉(zhuǎn)化為long型,其中Integer型是包裝類型,long型是基礎(chǔ)類型 Integer a3=10; long b3=a3.longValue(); System.out.println("4、將Integer型轉(zhuǎn)化為long型:"+b3); //5、將Integer型轉(zhuǎn)化為L(zhǎng)ong型,其中Integer、Long型都是包裝類型 Integer a4=10; Long b4=a4.longValue(); System.out.println("5、將Integer型轉(zhuǎn)化為L(zhǎng)ong型:"+b4); }
輸出結(jié)果:
1、將long型轉(zhuǎn)化為int型:10
2、將int型轉(zhuǎn)化為long型:10
3、將Long型轉(zhuǎn)換為int型:10
4、將Integer型轉(zhuǎn)化為long型:10
5、將Integer型轉(zhuǎn)化為L(zhǎng)ong型:10
補(bǔ)充知識(shí):JAVA中Long與Integer比較容易犯的錯(cuò)誤
今天使用findbugs掃描項(xiàng)目后發(fā)現(xiàn)很多高危漏洞,其中非常常見的一個(gè)是比較兩個(gè)Long或Integer時(shí)直接使用的==來比較。 其實(shí)這樣是錯(cuò)誤的。
因?yàn)長(zhǎng)ong與Ineger都是包裝類型,是對(duì)象。 而不是普通類型long與int , 所以它們?cè)诒容^時(shí)必須都應(yīng)該用equals,或者先使用longValue()或intValue()方法來得到他們的基本類型的值然后使用==比較也是可以的。
但是有一種特殊情況, 其實(shí)Long與Integer都將 -128~127 這些對(duì)象緩存了。 可以看看Long類型源碼里面有一個(gè)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); } }
先看看這個(gè)例子:
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)); } }
打印的結(jié)果是:
a == b ? true
c == d ? false
原因
首先來看看 Long a = 5L ; 它是如何將一個(gè)基本類型long包裝成一個(gè)對(duì)象Long的 。
可以寫一個(gè)測(cè)試類,然后反編譯一下,看看java它是如何解析Long a = 5L這樣一條命令的 。
測(cè)試類如下:
public class Test06 { Long l = 3L; }
然后使用javap -verbose Test06 就能看到反編譯的結(jié)果了, 下面是輸出的部分:
{ 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可以看出調(diào)用了Long的一個(gè)類方法Long.valueOf(Long) , 所以可以得到的結(jié)論是Long a = 5L實(shí)際上等于 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); }
一目了然,會(huì)先判斷基本類型的值如果在-128~127之間,就會(huì)直接從LongCache里面取出緩存的對(duì)象返回,否則就new一個(gè)新的Long對(duì)象返回 。
現(xiàn)在就不難理解Test05程序執(zhí)行得到的結(jié)果了,因?yàn)閍與b等于5,在-127~128之內(nèi),所以都是直接從LongCache里面返回的一個(gè)Long對(duì)象,所以他們?cè)谑褂?=比較的時(shí)候,就是相等的(對(duì)于對(duì)象類型來說,==比較的是兩個(gè)對(duì)象的引用指向堆中的地址) ,而c與d等于129,不在-127~128之間,所以他們他們是分別new出來的兩個(gè)新的Long對(duì)象,使用==來比較自然是不相等的了。
Long重寫了equals方法:
public boolean equals(Object obj) { if (obj instanceof Long) { return value == ((Long)obj).longValue(); } return false; }
它是先通過.longValue()方法獲取Long對(duì)象的基本類型long的值之后再做比較的。
所以對(duì)于Integer與Long的比較,最好是使用equals來比較才能確保得到我們想要的結(jié)果。
Integer與Long一樣,這里就不舉例了。
以上這篇java中l(wèi)ong(Long)與int(Integer)之間的轉(zhuǎn)換方式就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
淺析Java中comparator接口與Comparable接口的區(qū)別
本文要來詳細(xì)分析一下Java中Comparable和Comparator接口的區(qū)別,兩者都有比較的功能,那么究竟有什么區(qū)別呢,感興趣的Java開發(fā)者繼續(xù)看下去吧2016-10-10mybatis-generator自動(dòng)生成dao、mapping、bean配置操作
這篇文章主要介紹了mybatis-generator自動(dòng)生成dao、mapping、bean配置操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-08-08Maven?Web項(xiàng)目使用Cargo插件實(shí)現(xiàn)自動(dòng)化部署的詳細(xì)步驟
cargo ,它是一組幫助用戶實(shí)現(xiàn)自動(dòng)化部署,操作Web容器的工具,并且?guī)缀踔С炙械腤eb容器,這篇文章主要介紹了Maven?Web項(xiàng)目使用Cargo實(shí)現(xiàn)自動(dòng)化部署,需要的朋友可以參考下2023-02-02教你用springboot連接mysql并實(shí)現(xiàn)增刪改查
今天教各位小伙伴用springboot連接mysql并實(shí)現(xiàn)增刪改查功能,文中有非常詳細(xì)的步驟及代碼示例,對(duì)正在學(xué)習(xí)Java的小伙伴們有非常好的幫助,需要的朋友可以參考下2021-05-05Java 創(chuàng)建線程的3種方法及各自的優(yōu)點(diǎn)
這篇文章主要介紹了Java 創(chuàng)建線程的3種方法及各自的優(yōu)點(diǎn),文中講解非常細(xì)致,代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下2020-07-07SpringBoot+WebMagic實(shí)現(xiàn)網(wǎng)頁(yè)爬蟲的示例代碼
本文是對(duì)spring?boot+WebMagic+MyBatis做了整合,使用WebMagic爬取數(shù)據(jù),然后通過MyBatis持久化爬取的數(shù)據(jù)到mysql數(shù)據(jù)庫(kù),具有一定的參考價(jià)值,感興趣的可以了解一下2023-10-10Java8新特性之Base64詳解_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要為大家詳細(xì)介紹了Java8新特性之Base64的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06java實(shí)例方法被覆蓋,靜態(tài)方法被隱藏Explain(詳解)
下面小編就為大家?guī)硪黄猨ava實(shí)例方法被覆蓋,靜態(tài)方法被隱藏Explain(詳解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-05-05