java基本數據類型總結 類型轉換 final關鍵字的用法


java基本數據類型總結

 Java數據類型總結

     數據類型在計算機語言里面,是對內存位置的一個抽象表達方式,可以理解為針對內存的一種抽象的表達方式。接觸每種語言的時候,都會存在數據類型的認識,有復雜的、簡單的,各種數據類型都需要在學習初期去了解,Java是強類型語言,所以Java對於數據類型的規范會相對嚴格。數據類型是語言的抽象原子概念,可以說是語言中最基本的單元定義,在Java里面,本質上講將數據類型分為兩種:基本類型和引用數據類型。

一、基本數據類型:簡單數據類型是不能簡化的、內置的數據類型、由編程語言本身定義,它表示了真實的數字、字符和整數。

  1).Java中的基本數據類型有八種,即八大基本類型。具體如下:

  類型    稱呼  值域  表示范圍

  byte 字節型 8 bits -128~127

  int 整型 32 bits -2^31~(2^31-1)

  short 短整型 16 bits -2^15~(2^15-1)

  long 長整型 64 bits -2^63~(2^63-1)

  char 字符型 16 bits(Unicode) 0~65535

  float 浮點型 32 bits 直接賦值時必須在數字后加上f或F

  double 雙精度 64 bits 賦值時可以加d或D也可以不加

  boolean 布爾型 true/false 只有“真”或“假”兩種結果

  2)補充:char(字符型)中的一個字母或一個漢字對應一個整數,在ASCII中它的范圍為0~255

  3)其他:a. 定義一個byte變量,如: byte b = -256;

  由於-256超出了字節型的范圍,所以要使程序不報錯,可有如下幾種解決方法:

  1.更改變量的數據類型(如:將byte改為int);

  2.更改賦給變量的數值,使其包括在變量的數據類型的值域內;

  3.進行強制轉換: 如: byte b=(byte)-256;

  進行強制轉換后,雖然程序不再報錯,但是有可能會使原值的精度受到影響,即出現“溢出”現象。

  b.自動轉換:小范圍的整數類型值可通過賦值運算直接轉換為大范圍的原始類型值。從byte->short->char->int->long->float->double可以進行自動轉換;反之,則進行強制轉換。(如:假設iint型,bbyte型,可有:int i=b;假設ffloat型,要把它賦值給long型的變量,可有:long l = (long)f)

  c.定義一個浮點型數時,記得要在數值后面加上“f”或“F”。(如:float f = 10000.0f;)

  d.若定義char c=a;定義int n=c;則輸出的n值為“a”的ASCII值,即97

 

二、對象類型:Java語言本身不支持C++中的結構(struct)或聯合(union)數據類型,它的復合數據類型一般都是通過類或接口進行構造,類提供了捆綁數據和方法的方式,同時可以針對程序外部進行信息隱藏。

  1).對象類型(引用類型)包括: 

類、接口類型、數組類型、枚舉類型(Java 枚舉(enum) 詳解7種常見的用法網址 https://blog.csdn.net/qq_27093465/article/details/52180865)、注解類型。

區別:

基本數據類型在被創建時,在棧上給其划分一塊內存,將數值直接存儲在棧上。

引用數據類型在被創建時,首先要在棧上給其引用(句柄)分配一塊內存,而對象的具體信息都存儲在堆內存上,然后由棧上面的引用指向堆中對象的地址。

例如,有一個類Person,有屬性name,age,帶有參的構造方法,

Person p = new Person("zhangsan",20);

在內存中的具體創建過程是:

1.首先在棧內存中位其p分配一塊空間;

2.在堆內存中為Person對象分配一塊空間,並為其三個屬性設初值"",0;

3.根據類Person中對屬性的定義,為該對象的兩個屬性進行賦值操作;

4.調用構造方法,為兩個屬性賦值為"Tom",20;(注意這個時候p與Person對象之間還沒有建立聯系);

5.將Person對象在堆內存中的地址,賦值給棧中的p;通過引用(句柄)p可以找到堆中對象的具體信息。

三:java數據類型在內存中的存儲:

1)基本數據類型的存儲原理:所有的簡單數據類型不存在“引用”的概念,基本數據類型都是直接存儲在內存中的內存棧上的,數據本身的值就是存儲在棧空間里面,而Java語言里面八種數據類型是這種存儲模型;

2)引用類型的存儲原理:引用類型繼承於Object類(也是引用類型)都是按照Java里面存儲對象的內存模型來進行數據存儲的,使用Java內存堆和內存棧來進行這種類型的數據存儲,簡單地講,“引用”是存儲在有序的內存棧上的,而對象本身的值存儲在內存堆上的;

區別:基本數據類型和引用類型的區別主要在於基本數據類型是分配在棧上的,而引用類型是分配在堆上的(需要java中的棧、堆概念),

基本類型和引用類型的內存模型本質上是不一樣的。

例1:我們分析一下”==“和equals()的區別。

首先,我定以兩個String對象

Stringa="abc";

Stringb="abc";

然后

if(a==b){

System.out.println("a==b");

}else{

System.out.println("a!=b");}

程序輸出a!=b

原因:a和b的地址是不相同的,a==b比較的是兩個變量的地址

例2:定義兩個基本類型

int a=4;

int b=4;

if(a==b){System.out.println("a==b");}

else

{System.out.println("a!=b");}

輸出:a==b

原因:==比較的是兩個變量的內容

猜想:不論是基本數據類型還是引用類型,他們都會先在棧中分配一塊內存,對於基本類型來說,這塊區域包含的是基本類型的內容;而對於對象類型來說,這塊區域包含的是指向真正內容的指針,真正的內容被手動的分配在堆上。

 

 

類型轉換  

 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).強制類型轉換:用圓括號括起來目標類型,置於變量前

 

final關鍵字的用法

、final修飾類中的屬性或者變量

              無論屬性是基本類型還是引用類型,final所起的作用都是變量里面存放的“值”不能變,我們可以只設置一次final變量的值。

  2、final修飾類中的方法

             作用:可以被繼承,但繼承后不能被重寫。

3、final修飾類

             作用:類不可以被繼承。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM