java的线程

定义:在java中,线程是程序中一个独立的执行流,它拥有自己的核心运行逻辑和状态。在操作系统中,线程是进程的一部分,是程序执行的最小单元。

重要性:多线程使得程序能够更好的利用CPU资源,同时处理多个任务,提升程序的响应速度和性能。

实现方式:

继承Thread类:通过扩展Thread类并重写其run()方法来定义线程的行为。

实现runable接口:通过实现runable接口并将该实现类的实例座位thread对象detarget来创建线程。

一、什么是线程

当线程启动后(线程对象调用start方法),它不能一直“独占”CPU运行,所以CPU需要在多线程之间切换,于是线程状态也会多次在运行、阻塞之间切换。

二、线程的生命周期

在线程的生命周期中:

经过:新建(new),就绪(Runable),运行(Running),阻塞(Blocked),死亡(dead)五种状态。

线程生命周期示例图

三、具体步骤详解

1、创建

public class XThread extends Thread{
    @Override
        public void run() {
            
        }
}
//新建就是new出对象
XThread thread = new XThread();  //这就是新建

当程序使用了new关键字创建了一个线程之后,该线程就处于一个新建状态(初始状态),此时它与其他java对象一样,仅仅由java虚拟机为其分配了内存,并初始化了其成员变量值。此时的线程对象没有表现出任何线程的动态特征,程序也不会执行线程的线程执行体。

2、就绪

当线程对象调用了thread.start()方法之后,该线程就处于就绪状态。

java虚拟机会为其创建方法调用栈和程序计数器,处于这个状态的线程并没有开始运行,它只是表示该线程可以运行了。从start()源码中看出,start()后添加到了线程列表,接着在native层添加到VM中,至于该线程何时开始运行,取决于JVM里线程调度器的调度(如果OS调度被选中了,就会进入到运行状态)

3、运行

当线程对象调用了Thread.start()方法之后,该线程就处于就绪状态。

添加到了线程列表中,如果OS调度选中了,就会进入到运行状态。

4、阻塞

阻塞状态是线程因为某种原因放弃CPU使用权,暂时停止运行。直到线程进入就绪状态,才有机会转到运行状态。阻塞的情况大概三种:

  • 等待阻塞:运行的线程执行wait()方法,JVM会把该线程放入了等待池。(wait会释放持有的锁)
  • 同步阻塞:运行的线程在获取对象的同步锁时,若该同步锁被别的线程占用,则JVM会把该线程放入锁池中
  • 其他阻塞:运行的线程执行sleep()或join()方法,或者发出了I/O请求时,JVM会把该线程置为阻塞状态。当sleep()状态超时。join()等待线程终止或者超时、或者I/O处理完毕时,线程重新转入阻塞状态。

线程睡眠:Thread.sleep(long millis)方法,使得线程转入到阻塞状态。

线程等待:

线程让步:

线程加入:

线程I/O:

线程唤醒:

5、死亡

  • run()方法执行完,线程正常结束
  • 线程抛出一个未捕获的exception或者error
  • 直接调用stop()
  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中,线程是程序执行的基本单元,用于并发执行任务。每个线程都有自己的生命周期,包括创建、运行、阻塞和终止。线程的创建可以通过继承Thread类或实现Runnable接口来实现。 线程池则是Java中一种高效的线程管理机制,它预先创建一定数量的工作线程,并在需要执行任务时从线程池中获取线程进行处理,当任务完成后,线程会返回到线程池等待下一次调度,而不是立即结束。这样可以避免频繁地创建和销毁线程带来的开销,提高系统的性能和资源利用率。 以下是Java线程线程池的一些关键点: 1. **线程创建**: - **继承Thread类**:创建自定义线程类并重写run()方法。 - **实现Runnable接口**:创建Runnable接口的实现类,提供run()方法,然后用Thread构造函数创建Thread实例。 2. **线程状态**: - 新建(New):线程对象被创建但还未启动。 - 运行(Runnable):线程正在执行run()方法。 - 阻塞(Blocked):线程因某个条件而暂停,如I/O操作等待数据。 - 等待(Waiting):线程在调用wait()方法后,进入等待状态,直到被其他线程唤醒。 - 守护(Terminated):非守护线程完成或主线程结束,守护线程自动退出。 3. **线程池组件**: - ExecutorService:线程池的核心接口,提供了提交任务和控制线程的方法。 - ThreadPoolExecutor:实现了ExecutorService,包含核心线程数、最大线程数、任务队列等配置。 - ScheduledThreadPoolExecutor:支持定时和周期性任务。 4. **线程池的优势**: - **资源复用**:减少线程创建和销毁的开销。 - **线程管理和调度**:灵活设置线程数量、线程优先级和任务执行策略。 - **避免死锁**:由于任务有顺序地等待特定资源,减少了死锁的可能性。 - **可扩展性**:随着任务增加,线程池可以根据需要动态调整。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值