A. 如何獲得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+"的小狗");
}
}
B. 獲取java中String類型對象的內存地址值
String str1 = "abc";String str2 = "abc";System.out.println(str1==str2); //true
這樣就是true了
String str="abc";System.out.println(str.getBytes());
這個就是地址[B@7150bd4d B可能是類名 因為我的類是B @後面的大概是地址了 沒研究過 但是過去地址確實是這個
C. java如何查看對象的內存地址
java語言本身是沒有提供任何方法來查看內存地址的。關於載入類對象完全是由JVM來完成的,出於安全和方便的考慮,JVM管理內存對Java應用程序員是透明的。 可以考慮使用CE或者OD這兩款內存探測工具。應該能找到show()方法在內存中的入口地址。這兩款工具在編寫外掛方面是十分常用的。
D. 運行時java對象在內存中是什麼樣子的
JAVA對象是在堆中存儲的, 它在內存中的地址被存儲在一個或多個變數當中,類似於C中的指針,通過這些變數來操作對象, 對象理論上是不能獨立存在的,可以有多個變數存有它的地址,但不能沒有變數存它的地址,一旦沒有變數存有它的地址,就沒法對它進行操作, 對於程序運行來說,它就成了內存垃圾,正常情況下會被JAVA垃圾收集器給清除(少數異常情況可能回收不掉)
E. Java引用個對象是否在內存中真實存在還是只是一個地址
你表達的不夠清晰,我這樣跟你說吧!
User u = new User("亭台T","20","女");
這行語句其實分兩部分,從等號分開來說:
右邊new User();構造方法是真實的在內存中new出來一塊空間;
而你的u對象 實際上只是拿到了這塊空間的一個引用,或者說就是一個地址而已;
如果下面你再跟著一句代碼:
User d = u;
那麼d 也只是拿到了上面那塊地址的引用,也就是說u 和 d 現在為止,其實本質上是一個對象,因為內存中只有一個你最開始new 出來的那塊空間;
如果按如下方法來做你就會發現問題了:
u.setName("奇跡軟體工作室");
System.out.print(d.getName());
你會發現你set 了u對象的屬性,但是列印出來d的name也跟著變了,
也就是說,u和d都是引用,他們都引用了同一塊內存的真對象地址;
奇跡軟體工作室 東東程序猿 手打 請給分
F. java獲取變數,對象等的內存地址
獲取內存地址?這個不太現實的。
對於Java程序員來說,並不必顯示地對內存進行管理,一切都是交給Java虛擬機去做的,而且,你也不一定做得比Java虛擬機來得專業。
在你沒有運行java程序之前,沒有內存一說,只有運行以後,程序會被java虛擬機給編譯,運行,在編譯運行的過程中,程序員自定義的變數、類、方法、介面等等都會被放到不同的內存區域中,這時你只能通過調試獲取變數的值(此時的值是被放在內存中的)。在調試過程中,看見一個類或者方法有很長的一串字元,那就是內存地址,因為它不能像變數一樣,看見具體的值。
所以,你獲取不到內存地址的
希望我能幫到你
G. 如何獲取到JAVA對象所在的內存地址
1、首先打開java構造方法代碼。
(7)java對象內存地址擴展閱讀
當使用80386時,必須區分以下三種不同的地址:
邏輯地址:機器語言指令仍用這種地址指定一個操作數的地址或一條指令的地址。這種定址方式在Intel的分段結構中表現得尤為具體,它使得MS-DOS或Windows程序員把程序分為若干段。每個邏輯地址都由一個段和偏移量組成。
線性地址:針對32位CPU,線性地址是一個32位的無符號整數,可以表達高達2³² (4GB)的地址。通常用16進製表示線性地址,其取值范圍為0x00000000~0xffffffff。對64位CPU,線性地址是一個64位的無符號整數,可以表達高達2⁶⁴ 。
物理地址:也就是內存單元的實際地址,用於晶元級內存單元定址。物理地址也由32位無符號整數表示。
電腦的內存(尤其是指主存)是由許多「內存地址」所組成的,每個內存地址都有一個「物理地址」,能供CPU(或其他設備)訪問。一般,只有如BIOS、操作系統及部分特定之公用軟體(如內存測試軟體)等系統軟體;
能使用機器碼的運算對象或寄存器對物理地址定址,指示CPU要求內存控制器之類的硬體設備,使用內存匯流排或系統匯流排,亦或分別之控制匯流排、地址匯流排及數據匯流排,運行該程序之命令。
內存控制器的匯流排是由數條並行的線路所組成的,每條線路表示一個比特。匯流排的寬度因此依電腦不同,決定了可定址之存儲單位數量,以及每一單位內的比特數量。
計算機程序使用內存地址來運行機器碼、存儲及截取數據。大多數的應用程序無法得知實際的物理地址,而是使用電腦的內存管理單元及操作系統的內存映射,為「邏輯地址」或虛擬地址定址。
H. 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
}
}
I. Java的Object.hashCode的返回值到底是不是對象內存地址
在 Java 中,Object 對象的 hashCode() 方法會根據不同的對象生成不同的哈希值,默認情況下為了確保這個哈希值的唯一性,是通過將該對象的內部地址轉換成一個整數來實現的。
HashCode 其實只是在需要用到哈希演算法的數據結構中才有用,比如在 HashMap 和 Hashtable中。
HashCode 的用途是為了方便快速地查找對象,當你重寫了 hashCode() 後,HashCode 就不再是默認的對象內部地址了,而是你自己定義的一個值。
舉個例子你或許更明白點:假如 a 和 b 是兩個對象,你重寫了 equals() 方法,你的目的肯定是希望它們兩個相等。
現在有一個 HashMap,它的值是這樣的 map.put(a,c); map 中插入了一條數據,鍵是 a 值是 c,現調用 map.get(a) 可以返回對象 c,但是調用 map.get(b); 卻不能返回對象 c, 而在你最開始的定義中,a 和 b 兩個對象是相等的,相等的對象卻得不到相同的結果,這段代碼就不符合邏輯了。因為 HashMap 是根據鍵對象的 HashCode 來進行快速查找的,所以你必須保證 a 和 b 這兩個相同對象的 HashCode 也相同,因此你需要重寫 hashCode() 方法。另外,如果你要用到 HashSet,在這個例子中 a 和 b 可以同時插入到 HashSet 中,然而這兩個對象在邏輯上有時相等的,這不符合 HashSet 的定義。
總之,重寫 hashCode 是為了讓 Java 中所有使用到 Hash 演算法的數據結構能夠正常運行,當然如果你保證你的程序中完全不會用到 Hash 演算法,那麼你也可以不用重寫。
J. java的方法中new的對象存儲在內存中那個區域
這個對象存在堆中,還是棧中?
答:堆,new一個對象,一定是在堆中
方法內部new出來的對象,在哪裡存著?
答:堆,new出來對象的實例變數都存在堆上面。
棧,這個東西,需要理解為:線程運行時,才會創建,執行完,就沒了。
Person p = new Person();
上面這段代碼,在執行時,p壓入棧,通過局部變數表,找到對應的【實例數據】,執行完畢後釋放。