Java中线程状态

        当线程被创建并启动以后,它既不是一启动就进入了执行状态,也不是一直处于执行状态。在线程的生命周期中,有几种状态呢?在API中 java.lang.Thread.State 这个枚举中给出了六种线程状态:

这里先列出各个线程状态发生的条件,下面将会对每种状态进行详细解析。

线程状态发生条件
NEW(新建状态)创建了一个线程,启动之前处于该状态
RUNNABLE(可运行状态)线程正在执行任务(run方法中的代码)
BLOCKED(阻塞状态)获取synchronized锁对象失败
WAITING(无线等待状态)无限等待状态。获取Lock锁对象失败,就处于该状态,或者调用wait()方法 。 
TIMED_WAITING(限时等待状态)线程正在执行sleep()方法的时候
TERMINATED(消亡状态)线程执行完任务后


NEW(新建状态):创建了一个线程,启动之前处于该状态

public class test01 {
     public static void main(String[] args) {
    	 //创建线程
    	 Thread t = new Thread();
    	 //获取线程状态
 		 State s = t.getState();
 		System.out.println(s);
	}
}

 RUNNABLE(可运行状态):线程正在执行任务(run方法中的代码)

public class test02 {
	public static void main(String[] args) throws InterruptedException {
		//创建一个Runnable类型对象接口,覆盖重写run方法
		Runnable r = new Runnable() {
			@Override
			public void run() {
				for(;;); //死循环,处于一直运行状态
			}
		};
		Thread t = new Thread(r);
		//启动线程
		t.start();
		Thread.sleep(1000);//100毫秒保证子线程开始执行for(;;);这一行代码了
		System.out.println(t.getState());    //RUNNABLE
	}
}

BLOCKED(阻塞状态):获取synchronized锁对象失败

public static void main(String[] args) throws InterruptedException {
		Runnable r = new Runnable() {
			@Override
			public void run() {
				synchronized(this) {
					for(;;);
				}
			}
		};
		Thread t1 = new Thread(r);
		t1.start();
		Thread t2 = new Thread(r);
		t2.start();
		
		Thread.sleep(100);//100毫秒保证两个子线程已经启动,并开始执行代码了
		//获取并打印线程的状态
		System.out.println(t1.getState());
		System.out.println(t2.getState());
  }
}

WAITING(无线等待状态):无限等待状态。获取Lock锁对象失败,就处于该状态,或者调用wait()方法 。 

public class test04 {
	public static void main(String[] args) throws InterruptedException {
		//创建Lock锁
		Lock lock = new ReentrantLock();
		
		Runnable r = new Runnable() {
			@Override
			public void run() {
				    //上锁
					lock.lock();
					for(;;);
			}
		};
		Thread t1 = new Thread(r);
		t1.start();
		Thread t2 = new Thread(r);
		t2.start();
		Thread.sleep(100);//100毫秒保证两个子线程已经启动,并开始执行代码了
		//获取并打印线程的状态
		System.out.println(t1.getState());
		System.out.println(t2.getState());
	}
}

TIMED_WAITING(限时等待状态):线程正在执行sleep()方法的时候

public class test05 {
	public static void main(String[] args) throws InterruptedException {
		Runnable r = new Runnable() {
			@Override
			public void run() {
					try {
						Thread.sleep(1000);
					} catch (InterruptedException e) {
						e.printStackTrace();
					}
			}
		};
		Thread t = new Thread(r);
		t.start();
		
		Thread.sleep(100);//100毫秒保证子线程开始执行Thread.sleep(1000000);这一行代码了
		//获取并打印线程的状态
		System.out.println(t.getState());
	}
}

TERMINATED(消亡状态):线程执行完任务后

public class test06 {
	public static void main(String[] args) throws InterruptedException {
		Runnable r = new Runnable() {
			@Override
			public void run() {
				System.out.println("aaaa");
			}
		};
		Thread t = new Thread(r);
		t.start();
		
		Thread.sleep(10000);//1000毫秒子线程一定把任务执行完毕了
		//获取并打印线程的状态
		System.out.println(t.getState());
	  
	}
	
}
  • 35
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

会敲代码的阿宁.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值