java windows 取所有任務_Win下,通過Jstack截取Java進程中的堆棧信息

在Java軟件的使用過程中,有時會莫名的出現奇怪的問題。而這些問題常常無法使用日志信息定位,這時我們就需要通過查看進程內部線程的堆棧調用關系來分析問題出在哪里。

舉個例子,當我們在做某個操作時,莫名的會彈出多個警告框,其中有些信息是正常的,有些則不是。對于這些錯誤的警告信息,我們該如何定位是哪個位置的代碼出現了錯誤彈出的框呢? 我們就需要在彈框以后,去查看軟件的各個線程,去查找究竟是哪個線程導致了該問題。可是有時因為環境、時間等問題,我們根本不能拿著IDE去調試(你總不能拿著筆記本到客戶那里說,哥們我來調試下(防盜連接:本文首發自http://www.cnblogs.com/jilodream/ )吧), 只能通過工具軟件拍下內存快照,然后分析內存信息。

今天介紹一款常用的工具:Jstack

Jstack 是JDK自帶的工具,同時也是在JVM性能調優種出鏡率非常高的一款軟件。所以掌握它是非常有必要的。

Jstack可以生成JVM當前時間點的線程快照。

線程快照就是當前JVM內每一條線程正在執行的方法堆棧的集合。而生成線程快照的主要原因:

1、通過線程快照定位線程出現長時間停頓的原因,如線程間死鎖、死循環、請求外部資源導致的長時間等待

2、通過線程快照分析當前執行方法的調用關系來確定異常信息的源頭。

它的使用非常簡單:

(ps:前提是你已經裝有帶有Jstack的JDK。同時最好已經設置了環境變量。)

第一步: 通過Windows的任務管理器查看進程的PID

這里簡單說下什么是PID:PID就是各進程的身份標識,他是在軟件啟動后,由操作系統分配的唯一的、用來標識進程身份的一個標識

如圖

2d014e7048107912af68f87dcf1ca804.png

在進程頁簽下,查看 > 選擇列

eb7c678922510c08e11d1f3b1f1e0c7d.png

勾選PID 然后確定

ea5dbab70175222888a2977524be8b33.png

切到應用程序頁簽,選擇要快照內存的程序。圖片中選擇的是Android Studio。點擊右鍵轉到進程。

79fa24e34ed951c21215379dfe8e9b09.png

這里就查看到 Android Studio對應的PID是9952

第二步 打開命令行,執行Jstack程序

注意,如果沒有成功添加環境變量,那么這里只能在Jstack的路徑下執行,否則操作系統無法識別。

5461f38f892960542ea20368b9e31b36.png

如圖,這里一般有兩個運行參數,用來拍取內存快照,

他們的含義如下:

-l long listings,會打印出額(防盜連接:本文首發自http://www.cnblogs.com/jilodream/ )外的鎖信息,在發生死鎖時可以用jstack -l pid來觀察鎖持有情況

-m mixed mode,不僅會輸出Java堆棧信息,還會輸出C/C++堆棧信息(比如Native方法)

我們一般使用-l參數就可以滿足需要

格式如下 Jstack -l PID >> 123.txt

66cacbdd3fca4679a2dabc2c9274c0d7.png

ps 這里注意下 >>是重定向的意思,也就是將拍取到的快照定向輸出到987.txt中。>> 的兩次最好保持空格

這樣我們就會在命令行路徑下生成一個987.txt文件,同時將內存快照寫入到這個文本中

如下圖:

3b0e8f7a64f21fddb8e8bd80133ac18f.png

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/277486.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/277486.shtml
英文地址,請注明出處:http://en.pswp.cn/news/277486.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

docker mysql Exit 1

用laradock啟動mysql時,state總是 Exit 1 ,docker-compose build后也沒有效果 這時應該在~/.laradock/data(.env的DATA_PATH_HOST路徑)下,把mysql的數據文件刪除 這種情況常見于mysql安裝多版本&#xff0c…

redis基礎一_常用指令

# Redis configuration file example. # # Note that in order to read the configuration file, Redis must be # started with the file path as first argument: #./redis-server /path/to/redis.conf docker啟動redis: docker run -d -p 6379:6379 -v /home/anmin/Desktop/…

滴滴Booster移動APP質量優化框架 學習之旅 三

推薦閱讀: 滴滴Booster移動App質量優化框架-學習之旅 一 Android 模塊Api化演練 不一樣視角的Glide剖析(一) 滴滴Booster移動App質量優化框架-學習之旅 二對重復資源優化和無用資源優化進行了討論。這里對不可編譯無用assets資源優化進行討論。 先看微信Matrix-ApkC…

java 最后的異常_java – 最后不要拋出堆棧溢出異常

Error不是例外.所以捕捉任何異常都不會捕獲StackOverflowError.所以讓我們先來看一下“明顯的錯誤” – (這段代碼不太適合這個答案后面的說明):catch(Throwable e){System.out.println("Catch");}如果您進行此更改,您將發現代碼仍然不打印.但是它不會打印…

Colder框架硬核更新(Sharding+IOC)

目錄 引言控制反轉讀寫分離分庫分表 理論基礎設計目標現狀調研設計思路實現之過五關斬六將 動態對象動態模型緩存數據源移植查詢表達式樹深度移植數據合并算法事務支持實際使用展望未來引言 前方硬核警告:全文干貨11000字,請耐心閱讀 遙想去年這個時候&a…

python:小心類實例的屬性動態綁定機制

為什么80%的碼農都做不了架構師?>>> class Test:def __init__(self):self.__keyinitdef get_key(self):return self.__keydef set_key(self,key):self.__keykeyif __name__ __main__:obj Test()print(obj.get_key())#輸出初始值initobj.set_key(通過s…

java 獲取手機歸屬地_java 獲取手機歸屬地

java 獲取手機歸屬地[2021-01-30 20:46:44] 簡介:php去除nbsp的方法:首先創建一個PHP代碼示例文件;然后通過“preg_replace("/(\s|\&nbsp\;| |\xc2\xa0)/", " ", strip_tags($val));”方法去除所有nbsp即可。推薦:…

Atom常用功能插件

minimap代碼縮略圖插件 代碼粒子效果activate-power-mode 代碼格式化插件atom-beautify packages-->Atom Beautify-->Beautify進行格式化 標簽折疊 autoclose-html 轉載于:https://www.cnblogs.com/chenxi-hxl/p/9464120.html

mui aniShow 動畫屬性

aniShow: animationType //mui切換窗口的動畫效果;(默認為slide-in-right);1."auto": (String 類型 )自動選擇動畫效果,使用上次顯示窗口設置的動畫效果,如果是第一次顯示則默認動畫效果。 2.&qu…

java中和char功能相反的是_JAVA基礎語法

java的基礎語法Java中的程序可分為結構定義語句和功能執行語句.結構定義語句:用于聲明一個類或方法,功能執行語句用于實現具體的功能。功能執行語句:每條功能執行語句的結尾都必須用英文分號(;)結束。public修飾的類名必須和文件名一致(如果沒…

P1357 花園 (矩陣快速冪+ DP)

題意:一個只含字母C和P的環形串 求長度為n且每m個連續字符不含有超過k個C的方案數 m < 5 n < 1e15 題解:用一個m位二進制表示狀態 轉移很好想 但是這個題是用矩陣快速冪加速dp的 因為每一位的轉移都是一樣的 用一個矩陣表示狀態i能否轉移到狀態j 然后跑一遍 統計答案特…

IDEA設置類、方法注釋模板

類注釋模板 File -> Other Setting -> Default Setting打開默認設置 Editor -> File and Code Templates -> Files -> Class 找到類注釋模板&#xff0c;在public class前面添加模板注釋 /** * program: ${PROJECT_NAME}->${NAME} * description: ${descript…

Element.shadowRoot

Element.shadowRoot轉載于:https://www.cnblogs.com/yishenweilv/p/11083278.html

netty源碼分析之服務端啟動全解析

background netty 是一個異步事件驅動的網絡通信層框架&#xff0c;其官方文檔的解釋為 Netty is a NIO client server framework which enables quick and easy development of network applications such as protocol servers and clients. It greatly simplifies and stream…

捕魚達人java源代碼解析_捕魚達人源碼Java

【實例簡介】捕魚達人源碼Java實現的完整代碼,對應的源碼分析文章http://write.blog.csdn.net/postedit【實例截圖】【核心代碼】Fishlord├── bin│ ├── fishlord│ │ ├── Fish.class│ │ ├── Fishlord.class│ │ ├── Net.class│ │ ├─…

Android-一張圖理解MVP的用法

M和V通過P交互&#xff0c;M做了兩件事&#xff0c;開啟子線程做耗時操作&#xff0c;然后使用原生的Hander方式切回主線程回調結果給P。 M做的兩件事也可以使用比較流行的rxjava實現&#xff1a; 備注&#xff1a;圖片不清晰可以看這里 轉載于:https://www.cnblogs.com/develo…

Android 使用jtds遠程訪問數據庫

最近老師讓我用jtds這個jar包遠程訪問數據庫中的數據&#xff0c;雖然不難&#xff0c;但有幾個點還是要注意一下的。 1、jtds的jar包我使用的是1.2.7這個版本的&#xff0c;如果是Java工程使用的是1.3.1這個版本&#xff0c;Android工程不能使用1.3.1否則連接不上數據庫 2、遠…

java乘以2的位計算符號_java編程之:按位與運算,等運算規則

按位與運算符(&)參加運算的兩個數據&#xff0c;按二進制位進行“與”運算。運算規則&#xff1a;0&00; 0&10; 1&00; 1&11;即&#xff1a;兩位同時為“1”&#xff0c;結果才為“1”&#xff0c;否則為0例如&#xff1a;3&5 即 0000 0011 &a…

C語言文字加密程序的實現

前言&#xff1a;當今社會是一個信息社會&#xff0c;你的個人信息和聊天記錄極有可能被別有用心的人時時刻刻監視著&#xff0c;那么你想不想實現專屬于兩個人或一個小圈子的人在社交軟件上的交流不被任何其他人讀懂呢&#xff1f;下面就給大家提供一個原理極其簡單程序極其容…

菜鳥-es6

這里就不在嘮叨瀏覽器對es6的支持跟轉碼器了&#xff0c;稍微百度一下就ok let and const 變量 and 常量 什么是變量,什么是常量 - 都是存儲數據的容器, - 變量》即意思就是程序運行中可以發生變化的,- 常量》即程序運行中不可以發生改變&#xff0c;- 注意&#xff1a;常量…