日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

JVM系列之:再谈java中的safepoint

發(fā)布時(shí)間:2024/2/28 编程问答 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JVM系列之:再谈java中的safepoint 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

文章目錄

  • safepoint是什么
  • safepoint的例子
  • 線程什么時(shí)候會(huì)進(jìn)入safepoint
  • safepoint是怎么工作的
  • 總結(jié)

safepoint是什么

java程序里面有很多很多的java線程,每個(gè)java線程又有自己的stack,并且共享了heap。這些線程一直運(yùn)行呀運(yùn)行,不斷對(duì)stack和heap進(jìn)行操作。

這個(gè)時(shí)候如果JVM需要對(duì)stack和heap做一些操作該怎么辦呢?

比如JVM要進(jìn)行GC操作,或者要做heap dump等等,這時(shí)候如果線程都在對(duì)stack或者h(yuǎn)eap進(jìn)行修改,那么將不是一個(gè)穩(wěn)定的狀態(tài)。GC直接在這種情況下操作stack或者h(yuǎn)eap,會(huì)導(dǎo)致線程的異常。

怎么處理呢?

這個(gè)時(shí)候safepoint就出場(chǎng)了。

safepoint就是一個(gè)安全點(diǎn),所有的線程執(zhí)行到安全點(diǎn)的時(shí)候就會(huì)去檢查是否需要執(zhí)行safepoint操作,如果需要執(zhí)行,那么所有的線程都將會(huì)等待,直到所有的線程進(jìn)入safepoint。

然后JVM執(zhí)行相應(yīng)的操作之后,所有的線程再恢復(fù)執(zhí)行。

safepoint的例子

我們舉個(gè)例子,一般safepoint比如容易出現(xiàn)在循環(huán)遍歷的情況,還是使用我們之前做null測(cè)試用的例子:

public class TestNull {public static void main(String[] args) throws InterruptedException {List<String> list= new ArrayList();list.add("www.flydean.com");for (int i = 0; i < 10000; i++){testMethod(list);}Thread.sleep(1000);}private static void testMethod(List<String> list){list.get(0);} }

運(yùn)行結(jié)果如下:

標(biāo)紅的就是傳說中的safepoint。

線程什么時(shí)候會(huì)進(jìn)入safepoint

那么線程什么時(shí)候會(huì)進(jìn)入safepoint呢?

一般來說,如果線程在競(jìng)爭鎖被阻塞,IO被阻塞,或者在等待獲得監(jiān)視器鎖狀態(tài)時(shí),線程就處于safepoint狀態(tài)。

如果線程再執(zhí)行JNI代碼的哪一個(gè)時(shí)刻,java線程也處于safepoint狀態(tài)。因?yàn)閖ava線程在執(zhí)行本地代碼之前,需要保存堆棧的狀態(tài),讓后再移交給native方法。

如果java的字節(jié)碼正在執(zhí)行,那么我們不能判斷該線程是不是在safepint上。

safepoint是怎么工作的

如果你使用的是hotspot JVM,那么這個(gè)safepoint是一個(gè)全局的safepoint,也就是說執(zhí)行Safepoint需要暫停所有的線程。

如果你使用的是Zing,那么可以在線程級(jí)別使用safepoint。

我們可以看到生成的匯編語言中safepoint其實(shí)是一個(gè)test命令。

test指向的是一個(gè)特殊的內(nèi)存頁面地址,當(dāng)JVM需要所有的線程都執(zhí)行到safepint的時(shí)候,就會(huì)對(duì)該頁面做一個(gè)標(biāo)記。從而通知所有的線程。

我們?cè)儆靡粡垐D來詳細(xì)說明:

thread1在收到設(shè)置safepoint之前是一直執(zhí)行的,在收到信號(hào)之后還會(huì)執(zhí)行一段時(shí)間,然后到達(dá)Safepint暫停執(zhí)行。

thread2先執(zhí)行了一段時(shí)間,然后因?yàn)镃PU被搶奪,空閑了一段時(shí)間,在這段時(shí)間里面,thread2收到了設(shè)置safepoint的信號(hào),然后thread2獲得執(zhí)行權(quán)力,接著繼續(xù)執(zhí)行,最后到達(dá)safepoint。

thread3是一個(gè)native方法,將會(huì)一直執(zhí)行,知道safepoint結(jié)束。

thread4也是一個(gè)native方法,它和thread3的區(qū)別就在于,thread4在safepoint開始和結(jié)束之間結(jié)束了,需要將控制器轉(zhuǎn)交給普通的java線程,因?yàn)檫@個(gè)時(shí)候JVM在執(zhí)行Safepoint的操作,所以任然需要暫停執(zhí)行。

在HotSpot VM中,你可以在匯編語言中看到safepoint的兩種形式:’{poll}’ 或者 ‘{poll return}’ 。

總結(jié)

本文詳細(xì)的講解了JVM中Safepoint的作用,希望大家能夠喜歡。

本文作者:flydean程序那些事

本文鏈接:http://www.flydean.com/jvm-safepoint2/

本文來源:flydean的博客

歡迎關(guān)注我的公眾號(hào):程序那些事,更多精彩等著您!

總結(jié)

以上是生活随笔為你收集整理的JVM系列之:再谈java中的safepoint的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。