java對象的地址
A. java中對象的地址相同,是不是內容也是相同的啊
一般情況下JAVA中對象的地址相同內容也是相同的
這么說吧,對象地址和值是兩個不同的概念.
地址是存放值的地方,地址相當於對象在內存中的一塊區域且該區域且已經給它編上了號.
值相當於在該區域中存放的東西.
再打個比喻吧.
對象的地址就像是你學校的地址.
對象的值就像是你學校有多少學生.
對象是一種表示的概念如XXXX大學是你的學校.對象和地址都不變的情況下某個時刻它值相等的,但是在對象和地址都不變的情況下不同時刻值既可以相等(相同),也可以不相等(在一些情況下不同時刻值不相等).
B. 如何獲取到JAVA對象所在的內存地址
1、首先打開java構造方法代碼。
(2)java對象的地址擴展閱讀
當使用80386時,必須區分以下三種不同的地址:
邏輯地址:機器語言指令仍用這種地址指定一個操作數的地址或一條指令的地址。這種定址方式在Intel的分段結構中表現得尤為具體,它使得MS-DOS或Windows程序員把程序分為若干段。每個邏輯地址都由一個段和偏移量組成。
線性地址:針對32位CPU,線性地址是一個32位的無符號整數,可以表達高達2³² (4GB)的地址。通常用16進製表示線性地址,其取值范圍為0x00000000~0xffffffff。對64位CPU,線性地址是一個64位的無符號整數,可以表達高達2⁶⁴ 。
物理地址:也就是內存單元的實際地址,用於晶元級內存單元定址。物理地址也由32位無符號整數表示。
電腦的內存(尤其是指主存)是由許多「內存地址」所組成的,每個內存地址都有一個「物理地址」,能供CPU(或其他設備)訪問。一般,只有如BIOS、操作系統及部分特定之公用軟體(如內存測試軟體)等系統軟體;
能使用機器碼的運算對象或寄存器對物理地址定址,指示CPU要求內存控制器之類的硬體設備,使用內存匯流排或系統匯流排,亦或分別之控制匯流排、地址匯流排及數據匯流排,運行該程序之命令。
內存控制器的匯流排是由數條並行的線路所組成的,每條線路表示一個比特。匯流排的寬度因此依電腦不同,決定了可定址之存儲單位數量,以及每一單位內的比特數量。
計算機程序使用內存地址來運行機器碼、存儲及截取數據。大多數的應用程序無法得知實際的物理地址,而是使用電腦的內存管理單元及操作系統的內存映射,為「邏輯地址」或虛擬地址定址。
C. java 如何獲取對象內存地址
java中不建議直接獲取字元串內存地址,因為java不像c語言,獲取內存地址是C語言的強項,java的弱項。但是java內存地址還是有一個應用場景,就是判斷兩個字元串內存地址是否相等來判斷是否是同一個對象,用雙等號「==」來比較的。參考代碼如下:
public class Test01 {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
String str1="abc";
String str2=new String("abc");
System.out.println(str1 == str2);//輸出false
}
}
D. 如何獲得java對象的內存地址
在java中內存中的對象地址是可變的,所以獲得的內存地址有可能會變化。要獲得內存地址也只能通過Unsafe的方法來獲得,如下代碼示例:
packagecom.bijian.study;
importjava.lang.reflect.Field;
importsun.misc.Unsafe;
publicclassAddresser{
//實例化Unsafe 類
privatestaticUnsafeunsafe;
static{
try{
//得到field對象
Fieldfield=Unsafe.class.getDeclaredField("theUnsafe");
//設置獲取地址
field.setAccessible(true);
unsafe=(Unsafe)field.get(null);
}catch(Exceptione){
e.printStackTrace();
}
}
publicstaticlongaddressOf(Objecto)throwsException{
Object[]array=newObject[]{o};
longbaseOffset=unsafe.arrayBaseOffset(Object[].class);
intaddressSize=unsafe.addressSize();
longobjectAddress;
switch(addressSize){
case4:
objectAddress=unsafe.getInt(array,baseOffset);
break;
case8:
objectAddress=unsafe.getLong(array,baseOffset);
break;
default:
thrownewError("unsupportedaddresssize:"+addressSize);
}
return(objectAddress);
}
//列印地址的長度
publicstaticvoidmain(String...args)throwsException{
Objectmine="Hithere".toCharArray();
longaddress=addressOf(mine);
System.out.println("Addess:"+address);
//Verifyaddressworks-
printBytes(address,27);
}
//調用此方法得到地址
publicstaticvoidprintBytes(longobjectAddress,intnum){
//循環列印得到的地址。
for(longi=0;i<num;i++){
intcur=unsafe.getByte(objectAddress+i);
System.out.print((char)cur);
}
System.out.println();
}
}
運行結果:
E. 如何獲得java對象的內存地址
publicclass對象地址
{
publicstaticvoidmain(String[]args)
{
System.out.println(" ==========如何獲取對象地址?========== ");
init();
}//初始化!
privatestaticvoidinit()
{
//演示:創建對象!
Dogd1=newDog();
Dogd2=newDog("白色");
d1.show();
d2.show();
System.out.println(" 對象內存地址-->>對象所屬類型:"+d1+"<<--這就是對象內存中哈希值16進制的地址");
System.out.println("對象內存地址-->>對象所屬類型:"+d2+"<<--這就是對象內存中哈希值16進制的地址 ");
System.out.println("d1對象所屬類:"+d1.getClass());
System.out.println("d1對象所屬地址十進制:"+d1.hashCode()+"轉成16進制就和上面一樣了 ");
System.out.println("d2對象所屬類:"+d2.getClass());
System.out.println("d2對象所屬地址十進制:"+d2.hashCode()+"轉成16進制就和上面一樣了 ");
}
}
//測試類,小狗!
classDog
{
Stringcolor="黑色";
Dog(){}
Dog(Stringcolor){this.color=color;}
voidshow()
{
System.out.println("這是一個"+color+"的小狗");
}
}
F. 如何獲得java對象的內存地址
java中不建議直接獲取字元串內存地址,因為java不像c語言,獲取內存地址是C語言的強項,java的弱項。但是java內存地址還是有一個應用場景,就是判斷兩個字元串內存地址是否相等來判斷是否是同一個對象,用雙等號「==」來比較的。參考代碼如下:
public class Test01 {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
String str1="abc";
String str2=new String("abc");
System.out.println(str1 == str2);//輸出false
}
}