<address id="ousso"></address>
<form id="ousso"><track id="ousso"><big id="ousso"></big></track></form>
  1. java語言

    Java多線程的線程守護例子

    時間:2025-01-11 03:39:36 java語言 我要投稿
    • 相關推薦

    Java多線程的線程守護例子

      守護線程與普通線程寫法上基本么啥區別,調用線程對象的方法setDaemon(true),則可以將其設置為守護線程。下面是小編為大家帶來的Java多線程的線程守護例子,歡迎閱讀。

      Java多線程的線程守護例子

      核心說明:理解這句話下面可以不看了。

      守護與其他線程同時執行,當正在運行的線程都是守護線程時,Java 虛擬機退出。

      守護線程與普通線程寫法上基本么啥區別,調用線程對象的方法setDaemon(true),則可以將其設置為守護線程。

      守護線程使用的情況較少,但并非無用,舉例來說,JVM的垃圾回收、內存管理等線程都是守護線程。還有就是在做數據庫應用時候,使用的數據庫連接池,連接池本身也包含著很多后臺線程,監控連接個數、超時時間、狀態等等。

      setDaemon方法的詳細說明:

      public final void setDaemon(boolean on)將該線程標記為守護線程或用戶線程。當正在運行的線程都是守護線程時,Java 虛擬機退出。

      該方法必須在啟動線程前調用。

      該方法首先調用該線程的 checkAccess 方法,且不帶任何參數。這可能拋出 SecurityException(在當前線程中)。

      參數:

      on - 如果為 true,則將該線程標記為守護線程。

      拋出:

      IllegalThreadStateException - 如果該線程處于活動狀態。

      SecurityException - 如果當前線程無法修改該線程。

      另請參見:

      代碼如下

      isDaemon(), checkAccess()

      /**

      * Java線程:線程的調度-守護線程

      *

      * @author leizhimin 2009-11-4 9:02:40

      */

      public class Test {

      public static void main(String[] args) {

      Thread t1 = new MyCommon();

      Thread t2 = new Thread(new MyDaemon());

      t2.setDaemon(true); //設置為守護線程

      t2.start();

      t1.start();

      }

      }

      class MyCommon extends Thread {

      public void run() {

      for (int i = 0; i < 5; i++) {

      System.out.println("線程1第" + i + "次執行!");

      try {

      Thread.sleep(7);

      } catch (InterruptedException e) {

      e.printStackTrace();

      }

      }

      }

      }

      class MyDaemon implements Runnable {

      public void run() {

      for (long i = 0; i < 9999999L; i++) {

      System.out.println("后臺線程第" + i + "次執行!");

      try {

      Thread.sleep(7);

      } catch (InterruptedException e) {

      e.printStackTrace();

      }

      }

      }

      }

      后臺線程第0次執行!

      線程1第0次執行!

      線程1第1次執行!

      后臺線程第1次執行!

      后臺線程第2次執行!

      線程1第2次執行!

      線程1第3次執行!

      后臺線程第3次執行!

      線程1第4次執行!

      后臺線程第4次執行!

      后臺線程第5次執行!

      后臺線程第6次執行!

      后臺線程第7次執行!

      Process finished with exit code 0

      從上面的執行結果可以看出:

      前臺線程是保證執行完畢的,后臺線程還沒有執行完畢就退出了。

      實際上:JRE判斷程序是否執行結束的.標準是所有的前臺執線程行完畢了,而不管后臺線程的狀態,因此,在使用后臺縣城時候一定要注意這個問題。

      后臺線程(守護線程)

      所謂的后臺線程,是指在程序運行的時候在后臺提供一種通用服務的線程,并且這種線程并不屬于程序中不可或缺的部分。因此當所有的非后臺線程結束時,程序也就終止了,同時會殺死所有后臺線程。反過來說,只要有任何非后臺線程(用戶線程)還在運行,程序就不會終止。后臺線程在不執行finally子句的情況下就會終止其run方法。后臺線程創建的子線程也是后臺線程。

      下面是一個后臺線程的示例:

      代碼如下

      package demo.thread;

      import java.util.concurrent.TimeUnit;

      public class DaemonDemo implements Runnable {

      @Override

      public void run() {

      try {

      while (true) {

      Thread.sleep(1000);

      System.out.println("#" + Thread.currentThread().getName());

      }

      } catch (InterruptedException e) {

      e.printStackTrace();

      } finally {// 后臺線程不執行finally子句

      System.out.println("finally ");

      }

      }

      public static void main(String[] args) {

      for (int i = 0; i < 10; i++) {

      Thread daemon = new Thread(new DaemonDemo());

      // 必須在start之前設置為后臺線程

      daemon.setDaemon(true);

      daemon.start();

      }

      System.out.println("All daemons started");

      try {

      TimeUnit.MILLISECONDS.sleep(1000);

      } catch (InterruptedException e) {

      // TODO Auto-generated catch block

      e.printStackTrace();

      }

      }

      }

      運行結果:

      All daemons started

      #Thread-2

      #Thread-3

      #Thread-1

      #Thread-0

      #Thread-9

      #Thread-6

      #Thread-8

      #Thread-5

      #Thread-7

      #Thread-4

      分析:從結果可以看出,十個子線程并沒有無線循環的打印,而是在主線程(main())退出后,JVM強制關閉所有后臺線程。而不會有任何希望出現的確認形式,如finally子句不執行。


    【Java多線程的線程守護例子】相關文章:

    java的多線程04-09

    java多線程05-11

    java多線程教程04-22

    java語言的多線程04-19

    java多線程介紹05-28

    Java多線程的用法介紹03-29

    Java實現多線程的方法04-15

    Java多線程的基本使用08-03

    如何使用java多線程05-04

    <address id="ousso"></address>
    <form id="ousso"><track id="ousso"><big id="ousso"></big></track></form>
    1. 日日做夜狠狠爱欧美黑人