java多线程中校验一个后台线程中创建一个新线程,新线程是否是后台线程

    今晚在看Think In Java的时候,看到后台线程这一小节,突然有个想法,如果在一个后台线程里面创建一个非后台线程(不显示的设置setDaemon(true)),
那么创建的非后台线程是否也变成了后台线程。
1、如果在线程中使用Thread开启一个线程:
<pre name="code" class="java">package com.hq.day0601;

import java.util.concurrent.TimeUnit;
/**
 * 简单的后台线程(守护线程)练习,该练习主要演示的是后台线程在最后一个非后台线程结束后,也会被关闭
 * @author Administrator
 *
 */
public class SimpleDaemons implements Runnable {

	@Override
	public void run() {		
		try {
<span style="white-space:pre">			</span>//创建一个新的线程
			Thread thread = new Thread(new TestThread());
			thread.run();
			while(true){
				TimeUnit.MILLISECONDS.sleep(100);
				System.out.println("SimpleDaemons is Daemons:"+Thread.currentThread().isDaemon());
				System.out.println(Thread.currentThread() +" "+this );
			}
		} catch (InterruptedException e) {			
			e.printStackTrace();
			System.out.println("sleep() Interrupted");
		}		
	}
	
	public static void main(String[] args) throws Exception {
		for(int i = 0 ; i < 3;i++){
			Thread daemons = new Thread(new SimpleDaemons());
			daemons.setDaemon(true);
			daemons.start();
		}
		System.out.println("daemons start!");
		TimeUnit.SECONDS.sleep(1);
	}

}

/**
 * 校验守护线程中创建的线程是否是守护线程
 * @author Administrator
 *
 */
class TestThread implements Runnable {
	@Override
	public void run() {
		System.out.println("TestThread is Daemon:"+Thread.currentThread().isDaemon());
	}
}


 
运行结果如下:
<img src="https://img-blog.csdn.net/20160915225643951?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" />
说明如果使用这种方式,那么在后台线程中创建一个线程,也是守护线程
2.开启线程池的方式
代码如下:
<pre name="code" class="java">package com.hq.day0601;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.TimeUnit;
/**
 * 简单的后台线程(守护线程)练习,该练习主要演示的是后台线程在最后一个非后台线程结束后,也会被关闭
 * @author Administrator
 *
 */
public class SimpleDaemons implements Runnable {

	@Override
	public void run() {		
		try {
<span style="white-space:pre">			</span>//使用线程池的方式创建
			ExecutorService exec = Executors.newCachedThreadPool();
			exec.execute(new TestThread());	
                        exec.shutdown();//关闭线程池
			TimeUnit.MILLISECONDS.sleep(100);
			System.out.println("SimpleDaemons is Daemons:"+Thread.currentThread().isDaemon());
			System.out.println(Thread.currentThread() +" "+this );
		} catch (InterruptedException e) {			
			e.printStackTrace();
			System.out.println("sleep() Interrupted");
		}		
	}
	
	public static void main(String[] args) throws Exception {
		for(int i = 0 ; i < 3;i++){
			Thread daemons = new Thread(new SimpleDaemons());
			daemons.setDaemon(true);
			daemons.start();
		}
		System.out.println("daemons start!");
		TimeUnit.SECONDS.sleep(1);
	}

}

/**
 * 校验守护线程中创建的线程是否是守护线程
 * @author Administrator
 *
 */
class TestThread implements Runnable {
	@Override
	public void run() {
		System.out.println("TestThread is Daemon:"+Thread.currentThread().isDaemon());
	}
}


 

打印结果如下:



从结果打印可以看出,使用线程池创建的线程,不是后台线程。

综上所述:

1、后台线程中使用thread创建线程,创建的线程也是后台线程

2、在后台线程中使用线程池创建线程,与后台线程无关。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
package com.ljl.org.test4; /** *@DEMO:Interview *@Author:jilongliang *@Date:2013-4-17 * * 分别使用Runnable接口和Thread类编程实 编写一应用程序创建两个线程一个线程打印输出1—1000之间所有的奇数(Odd Number) * 另外一个线程打印输出1-1000之间所有的偶数(Even Number)要求两个线程随机休眠一 段时间后 继续打印输出下一个数 * * 创建线程有两种方式: 1.实现Runnable接口 2.继承Thread类 * 实现方式和继承方式有啥区别? * 实现方式的好处:避免了单继承的局限性 在定义线程时. * 建议使用实现方式 * 区别: * 继承Thread:线程代码存放Thread子类run方法 实现 * Runnable:线程代码存放接口的子类的run方法 * wait释放资源,释放锁 * sleep释放资源,不释放锁 */ @SuppressWarnings("all") public class Thread1 { public static void main(String[] args) { //方法一 /* OddNumber js = new OddNumber(); js.start(); EvenNumber os = new EvenNumber(); os.start(); while (true) { if (js.i1 == 1000 || os.i2 == 1000) { System.exit(-1); } } */ //方法二 OddNum on=new OddNum(); EvenNum en=new EvenNum(); new Thread(on).start(); new Thread(en).start(); while (true) { if (on.i1 == 1000 || en.i2 == 1000) { System.exit(-1); } } } } /** * ============================继承Thread的线程=============================== */ class EvenNumber extends Thread { int i2; @Override public void run() { for (i2 = 1; i2 <= 1000; i2++) { if (i2 % 2 == 0) { System.out.println("偶數" + i2); } try { sleep((int) (Math.random() * 500) + 500); } catch (Exception e) { } } } } class OddNumber extends Thread { int i1; @Override public void run() { for (i1 = 1; i1 <= 1000; i1++) { if (i1 % 2 != 0) { System.out.println("奇數" + i1); } try { sleep((int) (Math.random() * 500) + 500); } catch (Exception e) { } } } } /** * ============================实现Runnable的线程=============================== */ @SuppressWarnings("all") class OddNum implements Runnable { int i1; @Override public void run() { for (i1 = 1; i1 <= 1000; i1++) { if (i1 % 2 != 0) { System.out.println("奇數" + i1); } try { new Thread().sleep((int) (Math.random() * 500)+500); } catch (Exception e) { } } } } @SuppressWarnings("all") class EvenNum implements Runnable { int i2; @Override public void run() { for (i2 = 1; i2 <= 1000; i2++) { if (i2 % 2 == 0) { System.out.println("偶數" + i2); } try { /**在指定的毫秒数内让当前正在执行的线程休眠 * Math.random()一个小于1的随机数乘于500+500,随眠时间不会超过1000毫秒 */ //new Thread().sleep((int) (Math.random() * 500)+500); new Thread().sleep(1000);//也可以指定特定的参数毫秒 } catch (Exception e) { } } } }

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值