欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何定位java程序中占用cpu最高的線程堆棧信息

 更新時(shí)間:2022年11月11日 08:12:13   作者:尋找的路上  
這篇文章主要介紹了如何定位java程序中占用cpu最高的線程堆棧信息方法的相關(guān)資料,需要的朋友可以參考下

找出占用cpu最高的線程堆棧信息

在java編碼中,有時(shí)會(huì)因?yàn)榇中膶?dǎo)致cpu占用較高的情況,為了避免影響程序的正常運(yùn)行,需要找到問(wèn)題并解決。這里模擬一個(gè)cpu占用較高的場(chǎng)景,并嘗試定位到代碼行。

示例代碼如下:

public class Math {

    public static final int initData = 666;
    public static User user = new User();

    public int compute() {  //一個(gè)方法對(duì)應(yīng)一塊棧幀內(nèi)存區(qū)域
        int a = 1;
        int b = 2;
        int c = (a + b) * 10;
        return c;
    }

    public static void main(String[] args) {
        Math math = new Math();
        while (true){
            math.compute();
        }
    }
}

1,使用命令top -p ,顯示你的java進(jìn)程的內(nèi)存情況,pid是你的java進(jìn)程號(hào),比如18963

2,按H,獲取每個(gè)線程的內(nèi)存情況

3,找到內(nèi)存和cpu占用最高的線程tid,比如18964

4,轉(zhuǎn)為十六進(jìn)制得到 0x4a14,此為線程id的十六進(jìn)制表示

5,執(zhí)行 jstack 18963|grep -A 10 4a14,得到線程堆棧信息中 4cd0 這個(gè)線程所在行的后面10行,從堆棧中可以發(fā)現(xiàn)導(dǎo)致cpu飆高的調(diào)用方法

6,查看對(duì)應(yīng)的堆棧信息找出可能存在問(wèn)題的代碼

如上圖,定位到第15行代碼,是由于while循環(huán)導(dǎo)致的。

到此這篇關(guān)于如何定位java程序中占用cpu最高的線程堆棧信息的文章就介紹到這了,更多相關(guān)定位java程序中占用cpu最高的線程堆棧信息內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java對(duì)時(shí)間的簡(jiǎn)單操作實(shí)例

    Java對(duì)時(shí)間的簡(jiǎn)單操作實(shí)例

    這篇文章主要介紹了Java對(duì)時(shí)間的簡(jiǎn)單操作,實(shí)例分析了針對(duì)java.util.Date的各類(lèi)常見(jiàn)操作,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-01-01
  • Spring Bean三種注入方式詳解

    Spring Bean三種注入方式詳解

    本篇文章主要介紹了Spring Bean三種注入方式詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-11-11
  • Springboot FatJa原理機(jī)制源碼解析

    Springboot FatJa原理機(jī)制源碼解析

    這篇文章主要為大家介紹了Springboot FatJa原理機(jī)制源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • Java實(shí)現(xiàn)Random隨機(jī)數(shù)生成雙色球號(hào)碼

    Java實(shí)現(xiàn)Random隨機(jī)數(shù)生成雙色球號(hào)碼

    使用Random類(lèi)是Java中用于生成隨機(jī)數(shù)的標(biāo)準(zhǔn)類(lèi),本文主要介紹了Java實(shí)現(xiàn)Random隨機(jī)數(shù)生成雙色球號(hào)碼,具有一定的參考價(jià)值,感興趣的可以了解一下
    2023-11-11
  • Spring框架通過(guò)工廠創(chuàng)建Bean的三種方式實(shí)現(xiàn)

    Spring框架通過(guò)工廠創(chuàng)建Bean的三種方式實(shí)現(xiàn)

    這篇文章主要介紹了Spring框架通過(guò)工廠創(chuàng)建Bean的三種方式實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • SpringBoot實(shí)現(xiàn)發(fā)送短信的示例代碼

    SpringBoot實(shí)現(xiàn)發(fā)送短信的示例代碼

    這篇文章主要介紹了SpringBoot實(shí)現(xiàn)發(fā)送短信的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • 使用IDEA啟動(dòng)項(xiàng)目遇見(jiàn)ClassNotFoundException的解決方案

    使用IDEA啟動(dòng)項(xiàng)目遇見(jiàn)ClassNotFoundException的解決方案

    這篇文章主要介紹了使用IDEA啟動(dòng)項(xiàng)目遇見(jiàn)ClassNotFoundException的正確解決方案,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-06-06
  • Spring Boot讀取配置屬性常用方法解析

    Spring Boot讀取配置屬性常用方法解析

    這篇文章主要介紹了Spring Boot讀取配置屬性常用方法解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-09-09
  • 如何重寫(xiě)hashcode和equals方法

    如何重寫(xiě)hashcode和equals方法

    這篇文章主要介紹了如何重寫(xiě)hashcode和equals方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • 詳解如何全注解方式構(gòu)建SpringMVC項(xiàng)目

    詳解如何全注解方式構(gòu)建SpringMVC項(xiàng)目

    這篇文章主要介紹了詳解如何全注解方式構(gòu)建SpringMVC項(xiàng)目,利用Eclipse構(gòu)建SpringMVC項(xiàng)目,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2018-10-10

最新評(píng)論