守护线程
在Java语言中有两类线程:用户线程和守护线程。我们通俗的讲,任意一个守护线程都是整个JVM中所有线程的”大管家”;只要当前Java虚拟机中还有任意一个非守护线程没有结束,它们的守护线程就不能结束,要持续工作;只有当最后一个非守护线程结束时,守护线程才随着Java虚拟机一起结束工作。
- 其作用就是为其他线程的运行提供服务,就像是一个护道者,保证其他线程的顺利运行
用户线程设为守护线程
我们将用户线程设为守护线程的办法就是Thread类的setDaemon(true)方法。 假设我们创建一个线程t,然后我们将它设为守护线程,这时我们就应该注意:
- 守护线程应该永远不会去访问系统资源(比如数据库、文件等),因为它会在任何时候甚至正在进行某种操作时发生中断。
- 守护线程在运行期间定义并由守护线程创建的线程,都自然而然地是守护线程
- t.setDaemon(true)必须在t.start()之前调用,否则会发生IllegalThreadStateException异常。原因是不能把正在运行的常规线程设为守护线程
- 代码示例
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 | public class SubThread extends Thread{ int u1,v1; int result= 0 ; //构造方法 public SubThread(String name){ super (name); //随机产生0~100以内的整数 u1=( int )(Math.random()* 100 ); v1=( int )(Math.random()* 100 ); } @Override public void run() { //如果没有最大公约数,就进行计算 if (result== 0 ){ result= this .getMaxCommonDivisor(); System.out.println ( "运行····" + this ); while ( true ){ Thread.yield (); //暂停当前线程,执行其他线程 } } } //得到最大公约数 public int getMaxCommonDivisor() { int u=u1,v=v1,r=u; while (r!= 0 ){ u=v; v=r; r=u%v; } return v; } @Override public String toString() { String msg; msg= "threadName:" + this .getName ()+ ", ahead(优先级):" +getPriority (); String msg1= this .isDaemon ()? ",守护线程:" : "用户线程" ; msg=msg+msg1+ ".[" +u1+ "," +v1+ "的最大公约数是" +result+ "]" ; return msg; } } |
注意: public int getMaxCommonDivisor():该方法是为了得到u1、v1的最大公约数
以上就是Java 语言守护线程 Daemon Thread使用示例详解的详细内容,更多关于Java 守护线程Daemon Thread的资料请关注IT俱乐部其它相关文章!