日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

如何区分引用类型和原始类型

發布時間:2025/4/16 编程问答 42 豆豆
生活随笔 收集整理的這篇文章主要介紹了 如何区分引用类型和原始类型 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

?

下表列出了原始類型以及它們的對象封裝類。

原始類型和封裝類

原始類型 封裝類
boolean Boolean
char Character
byte Byte
short Short
int Integer
long Long
float Float
double Double

引用類型和原始類型的行為完全不同,并且它們具有不同的語義。例如,假定一個方法中有兩個局部變量,一個變量為 int 原始類型,另一個變量是對一個 Integer 對象的對象引用:

int i = 5; // 原始類型 Integer j = new Integer(10); // 對象引用

這兩個變量都存儲在局部變量表中,并且都是在 Java 操作數堆棧中操作的,但對它們的表示卻完全不同。(本文中以下部分將用通用術語 堆棧代替操作數堆棧或 局部變量表。)原始類型 int 和對象引用各占堆棧的 32 位。(要表示一個 int 或一個對象引用,Java 虛擬機實現至少需要使用 32 位存儲。) Integer 對象的堆棧項并不是對象本身,而是一個對象引用。

Java 中的所有對象都要通過對象引用訪問。對象引用是指向對象存儲所在堆中的某個區域的指針。當聲明一個原始類型時,就為類型本身聲明了存儲。前面的兩行代碼表示如下:

引用類型和原始類型具有不同的特征和用法,它們包括:大小和速度問題,這種類型以哪種類型的數據結構存儲,當引用類型和原始類型用作某個類的實例數據時所指定的缺省值。對象引用實例變量的缺省值為 null,而原始類型實例變量的缺省值與它們的類型有關。

許多程序的代碼將同時包含原始類型以及它們的對象封裝。當檢查它們是否相等時,同時使用這兩種類型并了解它們如何正確相互作用和共存將成為問題。程序員必須了解這兩種類型是如何工作和相互作用的,以避免代碼出錯。

例如,不能對原始類型調用方法,但可以對對象調用方法:

int j = 5; j.hashCode(); // 錯誤 //... Integer i = new Integer(5); i.hashCode(); // 正確

使用原始類型無須調用 new,也無須創建對象。這節省了時間和空間。混合使用原始類型和對象也可能導致與賦值有關的意外結果。看起來沒有錯誤的代碼可能無法完成您希望做的工作。例如:

import java.awt.Point; class Assign { public static void main(String args[]) { int a = 1; int b = 2; Point x = new Point(0,0); Point y = new Point(1,1); //1 System.out.println("a is " + a); System.out.println("b is " + b); System.out.println("x is " + x); System.out.println("y is " + y); System.out.println("Performing assignment and " + "setLocation..."); a = b; a++; x = y; //2 x.setLocation(5,5); //3 System.out.println("a is "+a); System.out.println("b is "+b); System.out.println("x is "+x); System.out.println("y is "+y); } }


這段代碼生成以下輸出:

a is 1 b is 2 x is java.awt.Point[x=0,y=0] y is java.awt.Point[x=1,y=1] Performing assignment and setLocation... a is 3 b is 2 x is java.awt.Point[x=5,y=5] y is java.awt.Point[x=5,y=5]


修改整數 a 和 b 的結果沒什么意外的地方。 b 的值被賦予整型變量 a,結果 a 的值增加了 1。這一輸出反映了我們希望發生的情況。但是,令人感到意外的,是在賦值并調用 setLocation之后 x 和 y 對象的輸出。我們在完成 x = y 賦值 之后特意對 x 調用了setLocation, x 和 y 的值怎么會相同呢?我們畢竟將 y 賦予 x,然后更改了 x,這與我們對整數 a 和 b 進行的操作沒什么不同。

這種混淆是由原始類型和對象的使用造成的。賦值對這兩種類型所起的作用沒什么不同。但它可能看起來所有不同。 賦值使等號 (=) 左邊的值等于右邊的值。這一點對于原始類型(如前面的 int a 和 b)是顯而易見的。對于非原始類型(如 Point 對象),賦值修改的是對象引用,而不是對象本身。因此,在語句

x = y;

之后, x 等于 y。換句話說,因為 x 和 y 是對象引用,它們現在引用同一個對象。因此,對 x 所作的任何更改也會更改 y。下面是 //1 處的代碼執行以后的情況:

執行 //2 處的賦值以后情況如下:

當在 //3 處調用 setLocation 時,這一方法是對 x 引用的對象執行的。因為 x 引用的 Point 對象也正是 y 所引用的對象,所以我們現在得到以下結果:

因為 x 和 y 引用同一個對象,所以對 x 執行的所有方法與對 y 執行的方法都作用于同一個對象。

區分引用類型和原始類型并理解引用的語義是很重要的。若做不到這一點,則會使編寫的代碼無法完成預定工作。

? 轉自:http://zhaohe162.blog.163.com/blog/static/3821679720123110755469/?suggestedreading&wumii

總結

以上是生活随笔為你收集整理的如何区分引用类型和原始类型的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。