线程的状态转换是线程控制的基础。线程状态总的可分为五大状态:分别是生、死、可运行、运行、等待/阻塞/睡眠。用一个图来描述如下:
1、新状态:线程对象已经创建,还没有在其上调用start()方法。
2、可运行状态:当线程有资格运行,但调度程序还没有把它选定为运行线程时线程所处的状态。当start()方法调用时,线程首先进入可运行状态。在线程运行之后或者从阻塞、等待或睡眠状态回来后,也返回到可运行状态。
3、运行状态:线程调度程序从可运行池中选择一个线程作为当前线程时线程所处的状态。这也是线程进入运行状态的唯一一种方式。
4、等待/阻塞/睡眠状态:线程仍旧是活的,但是当前没有条件运行。换句话说,它是可运行的,如果某个事件出现,他可以返回到可运行状态。当调用wait()方法的时候会进入阻塞状态;调用sleep()方法的时候会进入睡眠状态。
5、死亡态:当线程的run()方法完成时就认为它死去。这个线程对象也许是活的,但是,它已经不是一个单独执行的线程。线程一旦死亡,就不能复生。 如果在一个死去的线程上调用start()方法,会抛出java.lang.IllegalThreadStateException异常。
Thread类中run()和start()方法的区别如下:
run()方法:在本线程内调用该Runnable对象的run()方法,可以重复多次调用;
start()方法:启动一个线程,调用该Runnable对象的run()方法,不能多次启动一个线程;
package com.ljq.test;
publicclass ThreadTest {
/**
* 观察直接调用run()和用start()启动一个线程的差别
*
* @param args
* @throws Exception
*/
publicstaticvoid main(String[] args){
Thread thread=new ThreadDemo();
//第一种
//表明: run()和其他方法的调用没任何不同,main方法按顺序执行了它,并打印出最后一句
//thread.run();
//第二种
//表明: start()方法重新创建了一个线程,在main方法执行结束后,由于start()方法创建的线程没有运行结束,
//因此主线程未能退出,直到线程thread也执行完毕.这里要注意,默认创建的线程是用户线程(非守护线程)
//thread.start();
//第三种
//1、为什么没有打印出100句呢?因为我们将thread线程设置为了daemon(守护)线程,程序中只有守护线程存在的时候,是可以退出的,所以只打印了七句便退出了
//2、当java虚拟机中有守护线程在运行的时候,java虚拟机会关闭。当所有常规线程运行完毕以后,
//守护线程不管运行到哪里,虚拟机都会退出运行。所以你的守护线程最好不要写一些会影响程序的业务逻辑。否则无法预料程序到底会出现什么问题
//thread.setDaemon(true);
//thread.start();
//第四种
//用户线程可以被System.exit(0)强制kill掉,所以也只打印出七句
thread.start();
System.out.println("main thread is over");
System.exit(1);
}
publicstaticclass ThreadDemo extends Thread{
@Override
publicvoid run() {
for (int i =0; i <100; i++) {
System.out.println("This is a Thread test"+i);
}
}
}
}
publicclass ThreadTest {
/**
* 观察直接调用run()和用start()启动一个线程的差别
*
* @param args
* @throws Exception
*/
publicstaticvoid main(String[] args){
Thread thread=new ThreadDemo();
//第一种
//表明: run()和其他方法的调用没任何不同,main方法按顺序执行了它,并打印出最后一句
//thread.run();
//第二种
//表明: start()方法重新创建了一个线程,在main方法执行结束后,由于start()方法创建的线程没有运行结束,
//因此主线程未能退出,直到线程thread也执行完毕.这里要注意,默认创建的线程是用户线程(非守护线程)
//thread.start();
//第三种
//1、为什么没有打印出100句呢?因为我们将thread线程设置为了daemon(守护)线程,程序中只有守护线程存在的时候,是可以退出的,所以只打印了七句便退出了
//2、当java虚拟机中有守护线程在运行的时候,java虚拟机会关闭。当所有常规线程运行完毕以后,
//守护线程不管运行到哪里,虚拟机都会退出运行。所以你的守护线程最好不要写一些会影响程序的业务逻辑。否则无法预料程序到底会出现什么问题
//thread.setDaemon(true);
//thread.start();
//第四种
//用户线程可以被System.exit(0)强制kill掉,所以也只打印出七句
thread.start();
System.out.println("main thread is over");
System.exit(1);
}
publicstaticclass ThreadDemo extends Thread{
@Override
publicvoid run() {
for (int i =0; i <100; i++) {
System.out.println("This is a Thread test"+i);
}
}
}
}
相关推荐
在探究JVM线程状态以及Thread.sleep的实现原理时,我们首先需要了解Java线程与操作系统...理解线程状态以及这些状态之间的转换机制,有助于开发者在设计多线程程序时作出更为合理的决策,以提高程序的性能和可靠性。
下面将详细阐述进程与线程之间的区别及其相互作用。 #### 一、进程的概念 进程是程序的一次执行过程,是系统进行资源分配和调度的基本单位。每一个进程都有独立的地址空间和系统资源,包括但不限于内存段、打开的...
#### 五、Java线程:线程状态的转换 线程的状态主要有:新状态(New)、可运行状态(Runnable)、阻塞状态(Blocked)、等待状态(Waiting)、定时等待状态(Timed Waiting)以及终止状态(Terminated)。这些状态...
- 快速切换:线程切换的开销比进程切换小,因为它们共享大部分内存状态。 缺点: - 线程安全:多个线程访问共享资源可能导致数据不一致,需要同步机制如锁、信号量等来确保数据一致性。 - 资源限制:虽然线程轻量,...
- **线程状态**:Java线程有六种状态:NEW(新建)、RUNNABLE(可运行)、BLOCKED(阻塞)、WAITING(等待)、TIMED_WAITING(定时等待)、TERMINATED(终止)。 - **线程同步机制**:为了防止多线程环境下的数据...
- **解析**:这段代码展示了如何使用`System.Threading.Thread`类来获取当前线程的各种信息,包括线程ID、所在的应用程序域ID、上下文ID、线程名称、线程状态以及线程优先级等。 #### 四、线程控制方法 - `Start()`...
- **处理器状态信息**:通常由进程持有,用于保存上下文切换时所需的处理器状态信息,而线程则主要关注执行任务,不持有处理器状态信息。 - **进程控制信息**:线程需要包含调度相关信息以便于被调度执行,而与...
线程之间的切换比进程之间的切换要快得多,因为不需要切换地址空间,只需要保存和恢复少量的寄存器内容。 总结起来,进程和线程既有相似之处,也有不同之处。相似之处在于它们都是程序执行的抽象概念,都是CPU调度...
了解这些状态以及如何在它们之间转换是理解多线程的关键。 - **线程同步**:为了避免线程间的竞态条件,Java提供了`synchronized`关键字,它可以锁定代码块或方法,确保同一时间只有一个线程访问。 2. **线程池** ...
* 死锁是指两个或多个线程之间的相互等待,导致程序的执行被阻塞。 * 死锁的解决方法包括避免死锁的发生、检测死锁的发生和解决死锁的方法等。 Java多线程是Java语言中的一种重要的编程方式,用于实现多任务的并发...
线程间通信是多线程编程的关键部分,涉及线程之间的协作和数据交换。Java提供了`wait()`、`notify()`和`notifyAll()`等方法,用于实现线程间的等待和唤醒机制。此外,`ConcurrentHashMap`、`BlockingQueue`等并发...
- **调度与上下文切换:**线程的调度和上下文切换比进程更为轻量级,因为它们共享相同的地址空间,无需频繁地在不同的地址空间之间切换。 4. **调度机制:** - 进程的调度由操作系统负责,通常基于进程的优先级和...
- **线程**: 在计算机科学中,线程是程序执行的最小单元,一个进程中可以包含多个线程,它们共享进程资源,相互之间协作完成任务。 - **线程池**: PowerThreading线程管理器利用线程池的概念,预先创建一组线程,...
线程有多种状态,这些状态之间可以相互转换,了解这些状态对于我们编写高效的多线程程序非常重要。 新建状态(New) 在 Java 中,当我们创建一个线程对象时,它首先处于新建状态。在这个状态下,线程对象已经被...
4. 隔离性:进程之间相互隔离,一个进程崩溃不会影响其他进程;线程崩溃可能导致整个进程终止。 在多核或多处理器系统中,进程和线程的并行执行能充分利用硬件资源,提高系统性能。通常,I/O密集型任务更适合多进程...
它们之间通过调用特定的方法(如`start()`、`sleep()`、`join()`等)进行状态转换,生命周期从创建到结束经历这些状态。 创建与启动线程通常涉及创建`Thread`对象,然后调用`start()`方法。线程名称可以通过`set...
- **线程间的通信:** 允许线程发送信号告知其他线程状态改变,如任务完成或等待某个事件的发生。 - **避免死锁:** 死锁是指两个或多个线程在等待彼此持有的资源时陷入无限等待的状态。 **实现方式:** - **等待/...
了解这些状态以及状态之间的转换对理解和控制线程行为至关重要。 二、线程同步与通信 1. 同步:防止多个线程同时访问临界资源,常见的同步机制包括互斥量(Mutex)、信号量(Semaphore)、条件变量(Condition ...
- 可以将非线程安全的集合转换为线程安全的集合。 #### 七、线程的并发控制 - **原子操作**:Java提供了`AtomicInteger`等原子类,用于实现无锁编程。 - **显式锁(ReentrantLock)**:提供比`synchronized`更...