成都java開發培訓
達內成都高升橋中心

18011516507

熱門課程

成都java培訓機構哪家好?Java守護線程普通線程的例子

  • 時間:2020-07-15 17:43
  • 發布:成都達內
  • 來源:成都達內

我們一般創建的線程都是普通非守護線程,守護線程是為普通線程服務的。這個說法比較抽象。

具體一個很大的區別是:

JVM中所有的線程都是守護線程的時候,JVM就可以退出了--JVM不會等待守護線程是否運行結束

如果還有一個或以上的非守護線程則不會退出

非守護線程例子

public static void main(String[] args) throws Exception {

Thread runnableThread = new Thread(new Runnable() {

@Override

public void run() {

try {

Thread.sleep(100);

} catch (InterruptedException e) {

e.printStackTrace();

}

System.out.println("in runnable demo");

}

});

runnableThread.start();

System.out.println("in main");

Runtime.getRuntime().addShutdownHook(new Thread() {

@Override

public void run() {

System.out.println("JVM Exit!");

}

});

}

執行結果

in main

in runnable demo

JVM Exit!

可以看到,以為runnableThread默認是普通非守護線程,jvm必須等待他運行結束后才會關閉。

守護線程例子

setDaemon為true,就把線程設置成了守護線程。

public static void main(String[] args) throws Exception {

Thread runnableThread = new Thread(new Runnable() {

@Override

public void run() {

try {

Thread.sleep(100);

} catch (InterruptedException e) {

e.printStackTrace();

}

System.out.println("in runnable demo");

}

});

runnableThread.setDaemon(true);

runnableThread.start();

System.out.println("in main");

Runtime.getRuntime().addShutdownHook(new Thread() {

@Override

public void run() {

System.out.println("JVM Exit!");

}

});

}

執行結果

in main

JVM Exit!

可以看到,jvm沒有等待守護線程執行完畢就做了關閉。當主線程結束時,守護線程自動關閉,就免去了還要繼續關閉子線程的麻煩,如:Java垃圾回收線程就是一個典型的守護線程。

額外一個例子

public static void main(String[] args) throws Exception {

ThreadPoolExecutor executor = (ThreadPoolExecutor) Executors.newFixedThreadPool(1);

CompletableFuture.supplyAsync(() ->

{

try {

Thread.sleep(100);

} catch (InterruptedException e) {

e.printStackTrace();

} finally {

executor.shutdownNow();

}

System.out.println("in CompletableFutureDemo 1 ");

return "ddd";

}, executor);

System.out.println("in main");

Runtime.getRuntime().addShutdownHook(new Thread() {

@Override

public void run() {

System.out.println("JVM Exit!");

}

});

}

執行結果

in main

in CompletableFutureDemo 1

JVM Exit!

刪除外部傳入的executor,用默認的executor

public static void main(String[] args) throws Exception {

// ThreadPoolExecutor executor = (ThreadPoolExecutor) Executors.newFixedThreadPool(1);

CompletableFuture.supplyAsync(() ->

{

try {

Thread.sleep(100);

} catch (InterruptedException e) {

e.printStackTrace();

}

System.out.println("in CompletableFutureDemo 1 ");

return "ddd";

});

System.out.println("in main");

Runtime.getRuntime().addShutdownHook(new Thread() {

@Override

public void run() {

System.out.println("JVM Exit!");

}

});

}

執行結果

in main

JVM Exit!

當我們移除自定義的executor后發現jvm沒有等待我們的子線程運行結束就直接關閉了。

以為默認的CompletableFuture使用的是守護線程池。

public static CompletableFuture supplyAsync(Supplier supplier) {

return asyncSupplyStage(asyncPool, supplier);

}

上一篇:成都java培訓機構排名?送給你12個Git使用技巧!
下一篇:成都比較好的java培訓機構:JavaThead類的使用

成都比較好的java培訓機構:JavaThead類的使用

成都java培訓機構哪家好?Java守護線程普通線程的例子

成都java培訓機構排名?送給你12個Git使用技巧!

成都java就業怎么樣?Java8-函數式接口

選擇城市和中心
江西省

貴州省

廣西省

海南省

偷拍初高中女厕所视频