『壹』 java對象靜態變數放在jvm的什麼區域
從JVMS角度而言是在方法區(Method Area),對於特定的實現的話,例如Oracle HotSpot而言是在持久區(Permanent Area),HotSpot後續版本中會移除掉持久區的概念。 對於JVM內存區的劃分可參考 不會,因為類的靜態變數是此類的所有實例化對象全局共享的,即指向同一塊內存,只要一個對象更改了靜態變數,其他對象讀到的都是更改後的靜態變數,從設計上而言,也很容易理解,靜態變數也稱之為類變數,可以直接使用類名訪問而不需要通過類對象訪問,一樓所言有誤。 這要看你的業務需求,原則上是盡量減少不必要的靜態變數,對於一直常量類的話,你的變數就要包含靜態變數了。
『貳』 JVM內存布局及演變
-Xms1024m : 設置初始化內存分配大小,默認為本地內存的 1/64。
-Xmx1024m : 設置最大分配內存,默認為本地內存的1/4。
底層方法,與native方法相關。
線程私有,內存連續,存放8大基本類型+對象引用+實例的方法引用。
也叫PC寄存器,線程私有,保存當前執行指令的地址。
線程共享,內存不連續,存放對象實例。
-XX:+HeapDumpOnOutOfMemoryError : OOM
方法區是一個JVM規范上的邏輯概念,實際的位置根據不同JVM來看。
hotspot JVM虛擬機上將堆中的永久代作為方法區的一個存儲實現,為的是方法區也可以用堆內存的GC垃圾回收機制,而不用重新針對方法區做GC操作,直接使用堆內存的GC就可以了。
存放靜態變數(static)、常量(final)、類信息(Class,如構造方法、介面定義)、常量池。實例變數存在堆內存中,和方法區無關。
在Java7中永久代中存儲的部分數據已經開始轉移到Java Heap或Native Memory中了。比如,符號引用(Symbols)轉移到了Native Memory;字元串常量池(interned strings)、類的靜態變數(class statics)轉移到了Java Heap,永久代中存放類和類載入器的元數據信息。
移除堆中的永久區,用佔用本地內存的元空間(MetaSpace)來代替,存放類和類載入器的元數據信息。
符號引用沒有存在元空間中,而是繼續存在native heap中,這是兩個方式和位置,不過都可以算作是本地內存,在虛擬機之外進行劃分,沒有設置限制參數時只受物理內存大小限制,即只有占滿了操作系統可用內存後才OOM。
-XX:MetaspaceSize 來調整元空間初始大小,最大為本地內存大小。
感謝您的閱讀,本文已同步到 我的個人博客 ,您的關注是對我最大的鼓勵!
『叄』 Java方法區和堆分別儲存什麼
靜態變數、常量在方法區,所有方法,包括靜態和非靜態的,也在方法區。堆儲存對象、數組、非靜態變數。
『肆』 jvm各個區的作用
JVM虛擬機包括:
1.類裝載子系統
2.運行時數據區(內存模型)
堆(存放對象)
棧(線程)(具有先進後出的特性):每個線程啟動時都會從棧中分配一塊專屬的內 存空間,用來存放每一個方法的棧幀內存空間。棧幀內存中包括以下幾部分:
本地方法棧
方法區(元空間)
程序計數器:存放下一條指令所在單元的地址的地方
3.位元組碼執行引擎
將class文件放到方法區執行
修改程序計數器當前值
『伍』 Java內存中的棧,堆和方法區的用法有什麼不同
JAVA的JVM的內存可分為3個區:堆(heap)、棧(stack)和方法區(method)也叫靜態存儲區。
堆區:
存儲的全部是對象,每個對象都包含一個與之對應的class的信息。(class的目的是得到操作指令)
2.jvm只有一個堆區(heap)被所有線程共享,堆中不存放基本類型和對象引用,只存放對象本身
棧區:
每個線程包含一個棧區,棧中只保存基礎數據類型的對象和自定義對象的引用(不是對象),對象都存放在堆區中
2.每個棧中的數據(原始類型和對象引用)都是私有的,其他棧不能訪問。
3.棧分為3個部分:基本類型變數區、執行環境上下文、操作指令區(存放操作指令)。
方法區:
又叫靜態區,跟堆一樣,被所有的線程共享。方法區包含所有的class和static變數。
2.方法區中包含的都是在整個程序中永遠唯一的元素,如class,static變數。
『陸』 JAVA中類中的方法存儲在什麼地方
類載入時 方法信息保存在一塊稱為方法區的內存中, 並不隨你創建對象而隨對象保存於堆中。可參考《深入java虛擬機》前幾章。
另參考(他人文章):
如果instance method也隨著instance增加而增加的話,那內存消耗也太大了,為了做到共用一小段內存,Java 是根據this關鍵字做到的,比如:instance1.instanceMethod(); instance2.instanceMethod(); 在傳遞給對象參數的時候,Java 編譯器自動先加上了一個this參數,它表示傳遞的是這個對象引用,雖然他們兩個對象共用一個方法,但是他們的方法中所產生的數據是私有的,這是因為參數被傳進來變成call stack內的entry,而各個對象都有不同call stack,所以不會混淆。其實調用每個非static方法時,Java 編譯器都會自動的先加上當前調用此方法對象的參數,有時候在一個方法調用另一個方法,這時可以不用在前面加上this的,因為要傳遞的對象參數就是當前執行這個方法的對象。
『柒』 JVM 內存分哪⼏個區,每個區的作⽤是什麼
從JVM的觀點來看,它位於方法區域,對於具體的實現,如Oracle熱點,它位於永久區域,持久性的概念在熱點的後續版本中被刪除。
JVM內存區域的分區不能被引用,因為類的靜態變數是由類的所有實例化對象(即指向同一塊內存)全局共享的。
只要一個對象改變靜態變數,其他對象就讀取改變的靜態變數。
從設計的角度來看,靜態變數也很容易理解。
也稱為類變數,可以直接使用類名訪問,而不需要通過類對象訪問,第一層是錯誤的。
這取決於您的業務需求,原則上最小化不必要的靜態變數。
對於常數類,變數包含靜態變數。
『捌』 java線程存放在jvm的哪個區域方法又存放在哪個區呢
聊到JAVA中的方法,大多數人對於方法存儲在方法區還是棧區(虛擬機棧)是很迷茫的。其實方法是存在方法區的下面我們就細細說一下JVM中的 方法區 VS 棧區方法區:用於存儲已被虛擬機載入的類信息、常量、靜態變數、即時編譯器編譯後的代碼等數據,方法編譯出的位元組碼也是保存在這
『玖』 Java構造函數(方法)存儲在jvm哪個內存里
存放到方法區當中;
new出來的是實例對象,實例對象才是存放在堆當中;
構造函數對應的是<init>方法,方法信息隨著類載入器載入到方法區當中。
棧:
以棧幀為單位,存放的不是方法具體的結構,只是通常一個方法對應一個棧幀,對應的入棧出棧就是棧幀的入棧出棧。棧幀中有局部變數表,操作數棧,方法返回地址,動態鏈接。其中局部變數表存放局部變數,包括形參,非靜態方法默認在第一個索引存放一個this變數;操作數棧用於操作局部變數表和一些值的運算,比如讀取表中變數的值進行運算,或存放相應的值到局部變數表中;方法返回地址則是用於記錄對應方法的下一條指令的地址;動態鏈接是符號引用變成的直接引用。
堆:
存放實例對象,在jdk7開始,還存放靜態變數和字元串常量池
方法區:
存放類元信息,比如完整類名全稱,public,abstract等修飾符,實現的介面有序列表等;方法信息,比如修飾符,返回類型等;JIT代碼緩存,也就是被即時編譯器編譯後的熱點代碼,用於提高性能;域信息,也就是屬性信息,比如修飾符,類型等;運行時常量池,位元組碼文件中常量池的運行時表現,類似符號引用的記錄,不過蘊含的信息更為豐富,而且具有動態性。jdk6及以前,還存放靜態變數,運行時常量池中還存放字元串常量池,到了jdk7則移到了堆中。
『拾』 java中,靜態方法被調用是,存儲在內存的哪個區域是棧還是放大區還是兩者都有
在JDK8之前,靜態成員(靜態變數和靜態方法)都是存儲在方法區(永久代)中的靜態區中(這里指類被載入後,靜態成員的存儲位置)。但在JDK8之後,永久代被移除了,取而代之的是元空間(metaspace)。但元空間中存儲的主要是.class文件的元數據信息,靜態成員的存儲位置由方法區轉到了堆內存(heap)中。
不過,不管是JDK8,還是更早的版本中,靜態方法的執行(不僅僅是靜態方法,還有普通的成員方法)都是在棧內存(stack)中進行的。每個線程都會在棧內存中開辟一個棧,在調用方法時,對應的方法都會在執行這個方法的線程的棧中創建一個「棧幀」,棧幀中保存了局部變數表(基本數據類型和對象引用)、操作數棧、動態連接和返回地址等信息。等到方法執行完畢,棧幀被銷毀,對應的內存也將被釋放。