国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

JVM的內存分配方式

habren / 2314人閱讀

摘要:前言本篇講解在程序運行時,內存的分配是怎樣進行的虛擬機編譯時的內存存儲有三類靜態方法區存儲棧式存儲堆式存儲靜態存儲是指在編譯的時候就得確定這個數據的存儲需求,然后給它分配固定的內存,所以說靜態存儲不允許有可變的數據結構出現,因為可變的數據不

前言

本篇講解在java程序運行時,內存的分配是怎樣進行的?

java虛擬機編譯時的內存存儲有三類:
1.靜態(方法區)存儲
2.棧式存儲
3.堆式存儲

靜態存儲是指在編譯的時候就得確定這個數據的存儲需求,然后給它分配固定的內存,所以說靜態存儲不允許有可變的數據結構出現,因為可變的數據不會確定存儲空間

棧式存儲相比于靜態存儲正好相反,在編譯時,棧式存儲指定的存儲數據是不確定的,只有真正運行到這個數據的時候才知道,那時候才能為它分配內存空間

堆式存儲相對于棧式存儲,棧式存儲在分配空間前必須指定數據要分配多少內存,而堆式存儲則完全無法確定數據結構需要的內存空間,比如可變數組,對象實例,所以堆是由大片的可利用塊和空閑塊組成

棧和堆

靜態存儲相對簡單,所以我們著重分析棧和堆的關系和區別

區別
在棧中的數據一旦超過它的作用域之后,就會被釋放,內存會被其他數據占用
在堆中,分配的內存是由java虛擬機自動垃圾回收器管理,這些可變數組、對象在沒有引用變量指向他們的時候,才會變成垃圾,但仍然占著內存,之后再一個不確定的時間被垃圾回收器釋放掉

在一個JVM實例中,堆區只有一個,而棧可以有多個

關系
在堆中創建一個數據之后,可以在棧中定義一個變量,這個變量指向堆中的某個數據(指向數據的首地址),也就是說這個變量變成了堆中數據的引用變量,可以利用引用變量來訪問堆中的數據,這就是java的指針。

并且每個java應有都會有一個JVM實例,每個實例對應一個堆,在這個應有運行期間,所有的類實例和數組都放在這個堆中,在建立一個對象的時候會從兩個地方分配內存,在堆中是這個對象的實際值,而在棧(堆棧,也叫stack)中,分配的是堆中這個對象的索引

堆棧(stack)

先看下這張圖(嗯 畫的很形象)

JVM是基于堆棧的,每新建一個線程會分配一個堆棧,它是以幀為單位,有先進后出的特性(看圖可懂)
當激活一個java方法時,就為往堆棧中放入一個幀(這就是壓棧),在這個方法的執行過程中,這個幀就會用來保存數據

方法的存在有堆棧決定,而由于先進后出的形式,方法之間嵌套的越深,stack的內存就越難釋放,所以遞歸這樣的方法本人不推薦使用

下面貼出壓棧和出棧的具體實現
使用壓棧出棧來將字符串倒序

String value = "test 1234567890";
StringBuffer result = new StringBuffer();
 
Stack stack = new Stack();
 
for(char c : value.toCharArray()) {
  stack.push(c);
}
 
while (!stack.empty()) {
  result.append(stack.pop());
}
 
value = result.toString();

以上便是JVM的內存分配方式
覺得還可以的請點個贊,贊不了也可以收藏下;
總之,謝謝閱讀~

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/68060.html

相關文章

  • 萬萬沒想到,JVM內存結構面試題可以問這么難?

    摘要:方法區在實際內存空間站可以是不連續的。這一規定,可以說是給了虛擬機廠商很大的自由。但是值得注意的是,堆其實還未每一個線程單獨分配了一塊空間,這部分空間在分配時是線程獨享的,在使用時是線程共享的。 在我的博客中,之前有很多文章介紹過JVM內存結構,相信很多看多我文章的朋友對這部分知識都有一定的了解了。 那么,請大家嘗試著回答一下以下問題: 1、JVM管理的內存結構是怎樣的? 2、不同的...

    CloudwiseAPM 評論0 收藏0
  • 淺析JVM內存管理

    摘要:概要要理解的內存管理策略,首先就要熟悉的運行時數據區,如上圖所示,在執行程序的時候,虛擬機會把它所管理的內存劃分為多個不同的數據區,稱為運行時數據區。 這是一篇有關JVM內存管理的文章。這里將會簡單的分析一下Java如何使用從物理內存上申請下來的內存,以及如何來劃分它們,后面還會介紹JVM的核心技術:如何分配和回收內存。 JMM ( Java Memory Model )概要 show...

    Eric 評論0 收藏0
  • 十種JVM內存溢出情況,你碰到過幾種?

    摘要:內存溢出的情況就是從類加載器加載的時候開始出現的,內存溢出分為兩大類和。以下舉出個內存溢出的情況,并通過實例代碼的方式講解了是如何出現內存溢出的。內存溢出問題描述元空間的溢出,系統會拋出。這樣就會造成棧的內存溢出。 導言: 對于java程序員來說,在虛擬機自動內存管理機制的幫助下,不需要自己實現釋放內存,不容易出現內存泄漏和內存溢出的問題,由虛擬機管理內存這一切看起來非常美好,但是一旦...

    ShevaKuilin 評論0 收藏0
  • JVM解剖公園

    摘要:為此,引入轉換查找緩沖緩存最近的轉換記錄。這個優化技術,可以看到將原本對對象的字段訪問,替換為一個局部變量的訪問。當所有線程都在已知的位置停止的時候,被認為是到達了安全點。檢查安全點請求的代碼 showImg(https://segmentfault.com/img/bVbwfcz?w=1024&h=576); 1、JVM鎖粗化和循環原文標題:JVM Anatomy Quark #1:...

    imingyu 評論0 收藏0
  • Java對象分配簡要流程

    摘要:在一般應用中,不會逃逸的局部對象所占的比例很大,如果能使用棧上分配,那大量的對象就會隨著方法的結束而自動銷毀了,垃圾收集系統的壓力將會小很多。相關參數設置大對象直接進入年老代的閾值,當對象大小超過這個值時,將直接在年老代分配。 jvm系列 垃圾回收基礎 JVM的編譯策略 GC的三大基礎算法 GC的三大高級算法 GC策略的評價指標 JVM信息查看 GC通用日志解讀 jvm的card t...

    zorro 評論0 收藏0

發表評論

0條評論

最新活動
閱讀需要支付1元查看
<