java守护锁_Java 对象锁-synchronized()与线程的状态与生命周期与守护进程
synchronized(someObject){
//對象鎖
}
一、對象鎖 someObject 的使用說明:
1、對象鎖的返還。
當synchronize()語句執行完成。
當synchronize()語句執行出現異常。
當線程調用了wait()方法。
2、使用對象鎖保護的數據都必須是私有的。
也就是說someObject 變量必須是private
3、對象鎖具有可重入性。
一個線程在已經獲得對象鎖的情況下,可以再次請求獲得對象鎖。
二、線程的生命周期
線程run()方法結束之后,這個線程就是死的了。可能會被回收了。
線程周期以及線程轉換可以參考博文
jvm 內幕報文參考
這里所說的線程指程序執行過程中的一個線程實體。JVM 允許一個應用并發執行多個線程。Hotspot JVM 中的 Java 線程與原生操作系統線程有直接的映射關系。當線程本地存儲、緩沖區分配、同步對象、棧、程序計數器等準備好以后,就會創建一個操作系統原生線程。Java 線程結束,原生線程隨之被回收。操作系統負責調度所有線程,并把它們分配到任何可用的 CPU 上。當原生線程初始化完畢,就會調用 Java 線程的 run() 方法。run() 返回時,被處理未捕獲異常,原生線程將確認由于它的結束是否要終止 JVM 進程(比如這個線程是最后一個非守護線程)。當線程結束時,會釋放原生線程和 Java 線程的所有資源。
三、守護進程
現在理解守護進程就是 不影響主線程停止的線程。即使守護進程一直在執行,但是主進程停止了,并且jvm程序里面只有守護進程,那么jvm 將會退出。如下就是例子:
public?class?DaemonTest?{
public?static?void?main(String[]?args)?{
new?WorkerThread().start();
try?{
Thread.sleep(7500);
}?catch?(InterruptedException?e)?{
//?handle?here?exception
}
System.out.println("Main?Thread?ending")?;
}}class?WorkerThread?extends?Thread?{
public?WorkerThread()?{
//?When?false,?(i.e.?when?it's?a?user?thread),
//?the?Worker?thread?continues?to?run.
//?When?true,?(i.e.?when?it's?a?daemon?thread),
//?the?Worker?thread?terminates?when?the?main
//?thread?terminates.
setDaemon(true);
}
public?void?run()?{
int?count?=?0;
while?(true)?{
System.out.println("Hello?from?Worker?"+count++);
try?{
sleep(5000);
}?catch?(InterruptedException?e)?{
//?handle?exception?here
}
}
}}
運行結果為:
Hello?from?Worker?0
Hello?from?Worker?1
Main?Thread?ending
當守護進程打印了第一行的時候,
睡了5秒,
接下來醒了,打印第二行。
接著又睡了
主線程也睡了。
總結來看,就是守護進程其實不受主進程死活的影響。只要JVM活著,不過調用該守護進程的主進程死活,守護進程都可以運行,但是如果JVM死了,那守護進程也掛了。
總結
以上是生活随笔為你收集整理的java守护锁_Java 对象锁-synchronized()与线程的状态与生命周期与守护进程的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 一台十年前的台式电脑10年前的台式机还能
- 下一篇: 远程控制电脑不再是梦远程控制自己的电脑