国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

談談Java中整數類型(short int long)的存儲方式

2019-11-26 14:49:08
字體:
來源:轉載
供稿:網友

在java中的整數類型有四種,分別是 byte  short int long 其中byte只有一個字節 0或1,在此不詳細講解。

其他的三種類型如下:

1、
基本類型:short 二進制位數:16
包裝類:java.lang.Short
最小值:Short.MIN_VALUE=-32768 (-2的15此方)
最大值:Short.MAX_VALUE=32767 (2的15次方-1)

2、
基本類型:int 二進制位數:32
包裝類:java.lang.Integer
最小值:Integer.MIN_VALUE= -2147483648 (-2的31次方)
最大值:Integer.MAX_VALUE= 2147483647  (2的31次方-1)

3、
基本類型:long 二進制位數:64
包裝類:java.lang.Long
最小值:Long.MIN_VALUE=-9223372036854775808 (-2的63次方)
最大值:Long.MAX_VALUE=9223372036854775807 (2的63次方-1)

拿short類型舉例:

  首先需要明白在計算機中最高位為符號位,0表示正數,1表示負數。在計算機中數據是使用其補碼表示的,但正數補碼是其本身,負數的補碼是負數的源碼取反加一得到的補碼。

一、正數的原碼、反碼、補碼都相等

    例:0000 1010(在十進制中表示+10,左數第一位為符號位)
    它的原碼、反碼、補碼都是0000 1010

二、負數的原碼是其本身,負數的反碼是將符號不變,把符號后邊的數取反,對于負數的補碼 是把原碼取反后加1

    例:1000 1010(在十進制中表示-10)
    它的原碼是 1000 1010
    它的反碼是 1111 0101
    它的補碼是 1111 0110

    例如short類型: -1  二進制標示: 10000000 00000001(最大的負整數-1 )

          取反:          11111111 11111110  

          加1 補碼:      11111111 11111111  (最大的負整數-1在計算機中的標示方法)

明白了 以上這些再說short的二進制標示:

    先看這個: 最小的負整數 -32768     計算機中二進制標示:10000000   00000000

          最大的負整數-1     計算機中二進制標示:11111111  11111111

          0           計算機中二進制標示:00000000  0000000

         最小的正整數 1               計算機中二進制標示: 00000000 00000001

         最大的正整數:32767  計算機中二進制標示: 01111111  11111111

最小的負數-32768加1之后計算機中二進制標示為:10000000  00000001 一直加1直到到 11111111 11111111(-1)達到最大的負整數,然后再加1變為:1 00000000  0000000   注意此處字節長度為 17位,而short類型只取 16位即:00000000  0000000   所以-1+1之后變為0 然后00000000 00000000再一直加1直到 01111111  11111111 達到最大正整數(32767),32767再加1變為:10000000   00000000 即為最小的負整數 -32768(2^15)

ps:數據類型之間的轉換

1).簡單類型數據間的轉換,有兩種方式:自動轉換和強制轉換,通常發生在表達式中或方法的參數傳遞時。

自動轉換

具體地講,當一個較"小"數據與一個較"大"的數據一起運算時,系統將自動將"小"數據轉換成"大"數據,再進行運算。而在方法調用時,實際參數較"小",而被調用的方法的形式參數數據又較"大"時(若有匹配的,當然會直接調用匹配的方法),系統也將自動將"小"數據轉換成"大"數據,再進行方法的調用,自然,對于多個同名的重載方法,會轉換成最"接近"的"大"數據并進行調用。這些類型由"小"到"大"分別為 (byte,short,char)--int--long--float―double。這里我們所說的"大"與"小",并不是指占用字節的多少,而是指表示值的范圍的大小。

①下面的語句可以在Java中直接通過:

byte b;int i=b; long l=b; float f=b; double d=b;

②如果低級類型為char型,向高級類型(整型)轉換時,會轉換為對應ASCII碼值,例如

char c='c'; int i=c;

System.out.println("output:"+i);輸出:output:99;

③對于byte,short,char三種類型而言,他們是平級的,因此不能相互自動轉換,可以使用下述的強制類型轉換。

short i=99 ; char c=(char)i; System.out.println("output:"+c);輸出:output:c;

強制轉換

將"大"數據轉換為"小"數據時,你可以使用強制類型轉換。即你必須采用下面這種語句格式: int n=(int)3.14159/2;可以想象,這種轉換肯定可能會導致溢出或精度的下降。

2)表達式的數據類型自動提升, 關于類型的自動提升,注意下面的規則。

①所有的byte,short,char型的值將被提升為int型;

②如果有一個操作數是long型,計算結果是long型;

③如果有一個操作數是float型,計算結果是float型;

④如果有一個操作數是double型,計算結果是double型;

例, byte b; b=3; b=(byte)(b*3);//必須聲明byte。

3)包裝類過渡類型轉換

一般情況下,我們首先聲明一個變量,然后生成一個對應的包裝類,就可以利用包裝類的各種方法進行類型轉換了。例如:

①當希望把float型轉換為double型時:

float f1=100.00f;
Float F1=new Float(f1);
double d1=F1.doubleValue();//F1.doubleValue()為Float類的返回double值型的方法

②當希望把double型轉換為int型時:

double d1=100.00;
Double D1=new Double(d1);
int i1=D1.intValue();

簡單類型的變量轉換為相應的包裝類,可以利用包裝類的構造函數。即:Boolean(boolean value)、Character(char value)、Integer(int value)、Long(long value)、Float(float value)、Double(double value)

而在各個包裝類中,總有形為××Value()的方法,來得到其對應的簡單類型數據。利用這種方法,也可以實現不同數值型變量間的轉換,例如,對于一個雙精度實型類,intValue()可以得到其對應的整型變量,而doubleValue()可以得到其對應的雙精度實型變量。

4)字符串與其它類型間的轉換

其它類型向字符串的轉換

①調用類的串轉換方法:X.toString();

②自動轉換:X+"";

③使用String的方法:String.volueOf(X);

字符串作為值,向其它類型的轉換

①先轉換成相應的封裝器實例,再調用對應的方法轉換成其它類型

例如,字符中"32.1"轉換double型的值的格式為:new Float("32.1").doubleValue()。也可以用:Double.valueOf("32.1").doubleValue()

②靜態parseXXX方法

String s = "1";byte b = Byte.parseByte( s );short t = Short.parseShort( s );int i = Integer.parseInt( s );long l = Long.parseLong( s );Float f = Float.parseFloat( s );Double d = Double.parseDouble( s );

③Character的getNumericValue(char ch)方法

5)Date類與其它數據類型的相互轉換

整型和Date類之間并不存在直接的對應關系,只是你可以使用int型為分別表示年、月、日、時、分、秒,這樣就在兩者之間建立了一個對應關系,在作這種轉換時,你可以使用Date類構造函數的三種形式:

①Date(int year, int month, int date):以int型表示年、月、日
②Date(int year, int month, int date, int hrs, int min):以int型表示年、月、日、時、分
③Date(int year, int month, int date, int hrs, int min, int sec):以int型表示年、月、日、時、分、秒

在長整型和Date類之間有一個很有趣的對應關系,就是將一個時間表示為距離格林尼治標準時間1970年1月1日0時0分0秒的毫秒數。對于這種對應關系,Date類也有其相應的構造函數:Date(long date)。

獲取Date類中的年、月、日、時、分、秒以及星期你可以使用Date類的getYear()、getMonth()、getDate()、getHours()、getMinutes()、getSeconds()、getDay()方法,你也可以將其理解為將Date類轉換成int。

而Date類的getTime()方法可以得到我們前面所說的一個時間對應的長整型數,與包裝類一樣,Date類也有一個toString()方法可以將其轉換為String類。

有時我們希望得到Date的特定格式,例如20020324,我們可以使用以下方法,首先在文件開始引入,

import java.text.SimpleDateFormat;import java.util.*;java.util.Date date = new java.util.Date();//如果希望得到YYYYMMDD的格式SimpleDateFormat sy1=new SimpleDateFormat("yyyyMMDD");String dateFormat=sy1.format(date);//如果希望分開得到年,月,日SimpleDateFormat sy=new SimpleDateFormat("yyyy");SimpleDateFormat sm=new SimpleDateFormat("MM");SimpleDateFormat sd=new SimpleDateFormat("dd");String syear=sy.format(date);String smon=sm.format(date);String sday=sd.format(date);

總結:只有boolean不參與數據類型的轉換

(1).自動類型的轉換:

a.常數在表數范圍內是能夠自動類型轉換的

b.數據范圍小的能夠自動數據類型大的轉換(注意特例)

int到float,long到float,long到double 是不會自動轉換的,不然將會丟失精度

c.引用類型能夠自動轉換為父類的

d.基本類型和它們包裝類型是能夠互相轉換的

(2).強制類型轉換:用圓括號括起來目標類型,置于變量前

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 乌兰浩特市| 张家港市| 嘉峪关市| 雅江县| 西城区| 始兴县| 牟定县| 泗洪县| 湘潭县| 巴林右旗| 台东市| 安吉县| 巧家县| 陇川县| 唐河县| 章丘市| 灵璧县| 扬州市| 宝清县| 博客| 娄底市| 甘洛县| 武宁县| 敦煌市| 广丰县| 商洛市| 和硕县| 余姚市| 巨野县| 芷江| 北辰区| 吉林市| 铁岭市| 丰顺县| 湛江市| 晋州市| 绥棱县| 高台县| 南通市| 电白县| 桃江县|