1. 线程状态
新生状态
用 new 关键字建立一个线程后,该线程对象就处于新生状态。处于新生状态的线程有自己的内存空间,通过调用start()方法进入就绪状态。
就绪状态
处于就绪状态线程具备了运行条件,但还没分配到 CPU,线程处于就绪队列,等待系统为其分配 CPU。当系统选定一个等待执行的线程后,
它就会从就绪状态进入执行状态,该动作称为“CPU 调度”。
运行状态
运行状态的线程执行自己的 run 方法中的代码,直到等待某资源而阻塞或完成任何而死亡。如果在给定的时间片内没有执行结束,
就会被系统给换下来回到等待执行状态。
阻塞状态
处于运行状态的线程在某些情况下,如执行了 sleep(睡眠)方法,或等待 I/O 设备等资源,将让出 CPU 并暂时停止自己运行,进入阻塞状态。
在阻塞状态的线程不能进入就绪队列。只有当引起阻塞的原因消除时,如睡眠时间已到,或等待的I/O 设备空闲下来,线程便转入就绪状态,、
重新到就绪队列中排队等待,被系统选中后从原来停止的位置开始继续执行。
死亡状态
死亡状态是线程生命周期中的最后一个阶段。线程死亡的原因有三个,一个是正常运行的线程完成了它的全部工作;另一个是线程被强制性地终止,
如通过 stop 方法来终止一个线程【不推荐使用】;三是线程抛出未捕获的异常
2.获取线程基本信息的方法
1)static Thread currentThread() 返回目前正在执行的线程
1 public class TestThreadMethod {
2 //主方法,主线程
3 public static void main(String[] args) {
4 Thread t=Thread.currentThread();
5 //toString()方法得到的内容 为 [线程名称,线程的优先级,线程组的名称]
6 System.out.println(t.toString());
7
8 //线程线程类的对象
9 MyRunnable my=new MyRunnable();
10 Thread t1=new Thread(my);
11 Thread t2=new Thread(my);
12 Thread t3=new Thread(my);
13
14 //启动线程
15 t1.start();
16 t2.start();
17 t3.start();
18 /**在Thread类中一定有一个静态变量int,用于统计创建线程的个数 */
19 //线程的默认的命名规则 Thread - int类型的变量的值
20 }
21 }
22 class MyRunnable implements Runnable{
23
24 @Override
25 public void run() {
26 Thread t=Thread.currentThread();
27 System.out.println(t);
28 }
29 }
2)final String getName() 返回线程的名称
1 public class TestGetName {
2 public static void main(String[] args) {
3 //主线程的名称
4 Thread t=Thread.currentThread();
5 String name=t.getName();
6 System.out.println("主线程的名称:"+name);
7
8 //创建MyRunnable类的对象
9 MyRunnable my=new MyRunnable();
10 Thread t1=new Thread(my,"自定义的线程1");
11 Thread t2=new Thread(my,"线程2");
12 Thread t3=new Thread(my,"线程3");
13 System.out.println("修改之前:"+t3.getName());
14 //修改线程的名称
15 t3.setName("自定义的线程------------3");
16 System.out.println("修改之后:"+t3.getName());
17
18 //启动线程
19 t1.start();
20 t2.start();
21 t3.start();
22 }
23 }
3)final boolean isAlive() 判断线程是否处于活动状态
1 public class TestIsAlive {
2 public static void main(String[] args) {
3 //主线程
4 MyThread my=new MyThread();
5 System.out.println("线程my处于新生状态的是否处于活动状态:"+my.isAlive());
6 my.start();//启动线程
7 System.out.println("线程my处于就绪状态的线程是否处于活动状态:"+my.isAlive());
8 //主线程中的循环
9 for(int i=0;i<5;i++){
10 System.out.println("----------"+Thread.currentThread().getName()+"--------->"+i);
11 }
12 //主线程中的最后一句代码
13 System.out.println("my线程是否处于活动状态:"+my.isAlive());
14 }
15 }
16 class MyThread extends Thread{
17 @Override
18 public void run() {
19 for(int i=0;i<5;i++){
20 System.out.println(Thread.currentThread().getName()+"---------->"+i);
21 }
22 }
23 }
主线程结束,但分支线程未结束的情况
-----------------------------------------------------------------------------------
--------------------------------------------------------------------
主线程和分支线程均已结束的情况
-------------------------------------------------------------------
3.线程安全性问题
出现线程安全性问题的条件
1)多线程环境
2)有共享资源
3)对共享资源的非原子性操作
4.线程优先级问题
1)final int getPriority() 获取线程的优先级
2)final void setPriority(int priority) 设置线程的优先级
线程优先级1~10(高)
1 public class Test {
2 public static void main(String[] args) {
3 System.out.println("最高优先级:"+Thread.MAX_PRIORITY);
4 System.out.println("最低优先级:"+Thread.MIN_PRIORITY);
5 System.out.println("默认优先级:"+Thread.NORM_PRIORITY);
6 //主线程的优先级
7 Thread t=Thread.currentThread();
8 System.out.println("获取主线程的优先级:"+t.getPriority());
9
10 Thread t2=new Thread(new MyThread());
11 System.out.println("新建的线程优先级为:"+t2.getPriority());
12 /**
13 * 优先级超高越有可能先被调用执行,但是不一定
14 *
15 */
16 t2.setPriority(6);
17 System.out.println("t2线程的优先级:"+t2.getPriority());
18 // t2.setPriority(100); 非法参数,因为优先级只能是1-10之间的整数
19
20 }
21 }
22 class MyThread implements Runnable{
23 @Override
24 public void run() {
25
26 }
27 }