這期內(nèi)容當(dāng)中小編將會給大家?guī)碛嘘P(guān)如何深入了解Java虛擬機(jī)內(nèi)存,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。
成都創(chuàng)新互聯(lián)是一家集網(wǎng)站建設(shè),洛南企業(yè)網(wǎng)站建設(shè),洛南品牌網(wǎng)站建設(shè),網(wǎng)站定制,洛南網(wǎng)站建設(shè)報(bào)價,網(wǎng)絡(luò)營銷,網(wǎng)絡(luò)優(yōu)化,洛南網(wǎng)站推廣為一體的創(chuàng)新建站企業(yè),幫助傳統(tǒng)企業(yè)提升企業(yè)形象加強(qiáng)企業(yè)競爭力??沙浞譂M足這一群體相比中小企業(yè)更為豐富、高端、多元的互聯(lián)網(wǎng)需求。同時我們時刻保持專業(yè)、時尚、前沿,時刻以成就客戶成長自我,堅(jiān)持不斷學(xué)習(xí)、思考、沉淀、凈化自己,讓我們?yōu)楦嗟钠髽I(yè)打造出實(shí)用型網(wǎng)站。
程序計(jì)數(shù)器(Program Counter Register)
Java虛擬機(jī)棧(VM Stack)
本地方法棧(Native Method Stack)
方法區(qū)(method area)
堆(heap)
用來指示程序執(zhí)行哪一條指令,這跟匯編語言的程序計(jì)數(shù)器的功能在邏輯上是一樣的。JVM規(guī)范中規(guī)定,如果線程執(zhí)行的是非native方法,則程序計(jì)數(shù)器中保存的是當(dāng)前需要執(zhí)行的指令地址,如果線程執(zhí)行的是native方法,則程序計(jì)數(shù)器中的值undefined。每個線程都有自己獨(dú)立的程序計(jì)數(shù)器。為什么呢?因?yàn)槎嗑€程下,一個CPU內(nèi)核只會執(zhí)行一條線程中的指令,因此為了使每個線程在線程切換之后能夠恢復(fù)到切換之前的程序執(zhí)行的位置,所以每個線程都有自己獨(dú)立的程序計(jì)數(shù)器。
二、Java虛擬機(jī)棧本地方法棧(Native Method Stack)與虛擬機(jī)棧所發(fā)揮的作用是非常相似的,它們之間的區(qū)別不過是虛擬機(jī)棧為虛擬機(jī)執(zhí)行Java方法(也就是字節(jié)碼)服務(wù),而本地方法棧則為虛擬機(jī)使用到的Native方法服務(wù)。與虛擬機(jī)棧一樣,本地方法棧區(qū)域也會拋出StackOverflowError和OutOfMemoryError異常。
四、堆(heap)在C語言中,程序員可以通過malloc函數(shù)和free函數(shù)在堆上申請和釋放空間。那么在Java中是怎么樣的呢?Java中的堆是用來存儲對象本身的以及數(shù)組(當(dāng)然,數(shù)組引用是存放在Java棧中的),幾乎所有的對象實(shí)例都在這里分配內(nèi)存。在Java中,程序員基本不用去關(guān)心空間釋放的問題,Java的垃圾回收機(jī)制會自動進(jìn)行處理。另外,堆是被所有線程共享的,在JVM中只有一個堆。
上述就是小編為大家分享的如何深入了解Java虛擬機(jī)內(nèi)存了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。
網(wǎng)站欄目:如何深入了解Java虛擬機(jī)內(nèi)存
當(dāng)前網(wǎng)址:http://aaarwkj.com/article0/gipgio.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)公司、網(wǎng)站排名、App開發(fā)、小程序開發(fā)、面包屑導(dǎo)航
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)