java線程id
1. java如何獲取正在運行的線程的Id
使用:Thread.currentThread().getName() 就可以了
比如會輸出:pool-1-thread-7
2. java並發(1)線程模型
程序並不能單獨運行,只有將程序裝載到內存中,系統為它分配資源才能運行,而這種執行的程序就稱之為進程。程序和進程的區別就在於:程序是指令的集合,它是進程運行的靜態描述文本;進程是程序的一次執行活動,屬於動態概念
主要歸咎於兩點. 一個是由實現決定的,一個是由需求決定的.
線程由線程ID,程序計數器(PC)[用於指向內存中的程序指令],寄存器集合[由於存放本地變數和臨時變數]和堆棧[用於存放方法指令和方襪拍法參數等]組成。
以 Unix/Linux 的體系架構為例。
因為操作系統的資源納神是有限的,如果訪問資源的操作過多,必然會消耗過多的資源,而且如果不對這些操作加以區分,很可能造成資源訪問的沖突。所以,為了減少有限資源的訪問和使用沖突,對不同的操作賦予不同的執行等級(有多大能力做多大的事),用戶態(User Mode)和內核態(Kernel Mode)。
運行於用戶態的進程可以執行的操作和訪問的資源都會受到極大的限制,而運行在內核態的進程則可以執行任何操作並且在資源的使用上洞好虧沒有限制。
並發 :一個時間段內有很多的線程或進程在執行,但何時間點上都只有一個在執行,多個線程或進程爭搶時間片輪流執行。
並行 :一個時間段和時間點上都有多個線程或進程在執行。
線程有三種模型, 一對一,多對一,多對多.具體參考 一篇文章讀懂Java多線程模型 , 這里只描述一對一的情況.
每個用戶線程都映射到一個內核線程,每個線程都成為一個獨立的調度單元,由內核調度器獨立調度,一個線程的阻塞不會影響到其他線程,從而保障整個進程繼續工作.
JVM 沒有限定 Java 線程需要使用哪種線程模型來實現, JVM 只是封裝了底層操作系統的差異,而不同的操作系統可能使用不同的線程模型,例如 Linux 和 windows 可能使用了一對一模型,solaris 和 unix 某些版本可能使用多對多模型。所以一談到 Java 語言的多線程模型,需要針對具體 JVM 實現。
Sun JDK 1.2開始,線程模型都是基於操作系統原生線程模型來實現,它的 Window 版和 Linux 版都是使用系統的 1:1 的線程模型實現的。
3. Java如何定位佔用CPU比較高的問題
一、確定消耗CPU的Java進程
備註:
1、jstack 輸出的堆棧信息,線程id對應的16進制為小寫,查找時要統一按照小寫方式查找
2、jstack輸出為當前瞬間的堆棧信息,如果遇到間斷性出現CPU高的問題時,需要多輸出幾次
從上面方式定位到代碼Test.main(Test.java:4)處導致了CPU偏高的問題,那我們查看下代碼具體如何實現的?
代碼實現:
public class Test {
public static void main(String[] args) {
while(true) {
}
}
}
從代碼層面看該處實現了一個死循環,所以導致了線程佔用CPU偏高的問題。
4. java 多線程怎麼查看當前線程id
publicclass線程id
{
publicstaticvoidmain(String[]args)
{
System.out.println(" ==========多線程怎麼查看當前線程id========== ");
init();
}//初始化!
privatestaticvoidinit()
{
for(inti=0;i<2;i++)
{
newThread(newTestRunnable()).start();
}
}
}
{
//簡單測試直接用了靜態,偷懶了!
privatestaticinti=10;
publicvoidrun()
{
show();
}
synchronizedvoidshow()
{
while(i>=1)
System.out.println("當前執行的線程Id是:"+Thread.currentThread().getName()+"---->"+i--+" ");
}
}