首页 > 其他分享 > Thread 类的使用,如何创建、终止、等待一个线程以及获取线程的状态

Thread 类的使用,如何创建、终止、等待一个线程以及获取线程的状态

时间:2024-09-07 13:23:17浏览次数:13  
标签:Runnable Thread 创建 进程 线程 终止 public

线程是什么

线程是操作系统中调度的基本单位,是比进程更小的执行单元。线程在进程内部运行,共享该进程的资源,如内存和文件句柄,但每个线程都有自己的执行栈和程序计数器。


线程的主要特点包括:


轻量级:线程相较于进程更加轻量,创建和销毁的开销较小。

共享资源:同一进程中的线程共享该进程的内存空间和资源,从而可以更高效地进行数据交换。

并发执行:多个线程可以并发执行,充分利用多核处理器,提高程序的执行效率。

简化管理:线程的切换和管理相对于进程更为简单和迅速,有助于提升系统的响应速度。

线程的使用在现代操作系统中非常普遍,尤其是在需要高并发和高性能的应用场景中,例如网络服务器和多任务应用程序等。


为什么要有线程

首先, "并发编程" 成为 "刚需"。


单核 CPU 的发展遇到了瓶颈. 要想提高算力, 就需要多核 CPU. 而并发编程能更充分利用多核 CPU资源。

有些任务场景需要 "等待 IO", 为了让等待 IO 的时间能够去做一些其他的工作, 也需要用到并发编

程。


其次, 虽然多进程也能实现 并发编程, 但是线程比进程更轻量。


创建线程比创建进程更快.

销毁线程比销毁进程更快.

调度线程比调度进程更快.

创建出一个线程

在Java中,可以通过两种主要方式创建线程:继承Thread类和实现Runnable接口。下面分别介绍这两种方式,并附上代码示例。


方法一:继承 Thread 类

创建一个子类,继承Thread类,并重写run()方法,该方法包含了线程的执行代码。

创建子类的实例,然后调用start()方法来启动线程。

示例代码:


class MyThread extends Thread {

   @Override

   public void run() {

       // 线程执行的代码

       for (int i = 0; i < 5; i++) {

           System.out.println("Thread running: " + i);

           try {

               Thread.sleep(1000); // 暂停1秒

           } catch (InterruptedException e) {

               e.printStackTrace();

           }

       }

   }

}

public class ThreadExample {

   public static void main(String[] args) {

       Thread thread = new MyThread(); // 创建线程对象

       thread.start(); // 启动线程

   }

}


方法二:实现 Runnable 接口

创建一个类,实现Runnable接口,并实现run()方法。

创建Runnable接口的实例,将其传递给Thread构造函数,然后调用start()方法启动线程。

示例代码:


class MyRunnable implements Runnable {

   @Override

   public void run() {

       // 线程执行的代码

       for (int i = 0; i < 5; i++) {

           System.out.println("Runnable thread running: " + i);

           try {

               Thread.sleep(1000); // 暂停1秒

           } catch (InterruptedException e) {

               e.printStackTrace();

           }

       }

   }

}

public class RunnableExample {

   public static void main(String[] args) {

       MyRunnable myRunnable = new MyRunnable(); // 创建Runnable实例

       Thread thread = new Thread(myRunnable); // 将Runnable实例传递给Thread

       thread.start(); // 启动线程

   }

}


解析:


在这两个示例中,我们创建了一个简单的线程,该线程在运行时每秒打印一次数字(0到4)。

使用Thread.sleep(1000)使线程暂停1秒,这样可以模拟一些耗时的操作,也使得输出不至于淹没在快速的执行中。

调用start()方法时,Java虚拟机会调用线程的run()方法,而不是直接调用run()。这保证了线程的正确启动和管理。

总结:


通过这两种方式,Java允许灵活地创建和管理线程,开发者可以根据具体需求选择适合的方式。继承Thread类比较直接,但实现Runnable接口则可以实现更灵活的线程管理和资源共享。


标签:Runnable,Thread,创建,进程,线程,终止,public
From: https://blog.51cto.com/u_16274468/11944685

相关文章

  • JAVA线程池监控以及动态调整线程池
    1背景Java线程池源码分析 里虽然介绍了线程池的核心配置(核心线程数、最大线程数和队列大小)该如何配置,但是实际上业界也没有一个统一的标准。虽然有些所谓的"公式",但是不同的业务场景复杂多变,配置原则也不尽相同。从实际经验来看,IO密集型、CPU密集型应用在线程配置上就比较悬殊,因......
  • Java并发编程实战 06 | 为什么不建议使用线程优先级?
    什么是线程优先级?线程优先级是一个标识,用来提示操作系统或线程调度器哪个线程更重要、更需要优先执行。优先级通常是一个整数值。在Java中,线程优先级的设置范围从1到10,其中1是最低优先级,10是最高优先级。Java默认情况下,线程的优先级是5。优先级高的线程通常会......
  • Java并发编程实战 05 | 什么是线程组?
    1.线程组介绍在Java中,ThreadGroup用于表示一组线程。通过ThreadGroup,我们可以批量控制和管理多个线程,使得线程管理更加方便。ThreadGroup和Thread的关系就像它们的字面意思一样简单:每个线程(Thread)必定属于一个线程组(ThreadGroup),线程不能脱离线程组而单独存......
  • Java 线程池:参数、配置和常见问题以及案例示范
    Java线程池:参数、配置和常见问题以及案例示范线程池是提高系统性能和资源利用率的关键组件之一。通过合理配置线程池,可以有效地管理线程资源,避免系统过载,提升并发处理能力。本文将以电商交易系统为案例,详细讲解Java线程池的参数、配置、以及常见问题和解决方案以及在spr......
  • [Java并发]线程池拒绝策略的使用场景
    Java线程池中的四种拒绝策略在处理任务过载或资源不足时非常有用。每种策略适用于不同的场景:AbortPolicy(默认策略)描述:当线程池无法接受新任务时,该策略会直接抛出RejectedExecutionException,阻止任务被执行。使用场景:适用于希望立即得知线程池无法处理更多任务的场......
  • 【操作系统】线程同步之自旋锁
    自旋锁也是一种多线程同步的变量,使用自旋锁的线程会反复检查锁变量是否可用。自旋锁不会让出CPU,是一种忙等待状态,死循环等待锁被释放。(和互斥量最大的不同)自旋锁的特点:1、避免了进程或线程上下文切换的开销。2、操作系统内部很多地方使用的是自旋锁。3、自旋锁不适合在......
  • Java线程池详解
    线程池解释线程池采用了池化思想,能够有效的管理线程的生命周期,减少了每次获取资源的消耗,提高了资源的利用率。类似池化实现还有数据库连接池、HTTP连接池等好处减少了线程创建和销毁的开销提高了响应速度使得线程更加方便管理常见使用场景量大处理时间较短......
  • python测试开发基础---threading
    1.核心概念线程(Thread):线程是轻量级的进程,在同一进程内可以并行执行多个任务。线程共享进程的资源,如内存和文件描述符,但每个线程有自己的执行栈和局部变量。全局解释器锁(GIL):Python中的GIL限制了同一进程中多个线程的真正并行执行。它确保同一时间只有一个线程可以执行Pyth......
  • 多线程:线程安全
    线程安全多个线程,同时操作同一个共享资源的时候,可能会出现安全问题。例如:两个人来取钱的案例 publicclasstest{publicstaticvoidmain(String[]args){//1.创建一个账户对象。代表账户人的共享账户。Accountacc=newAccount("ICBC-110",1000......
  • 混合部署 | 在RK3568上同时部署RT-Thread和Linux系统-迅为电子
    RT-Thread是一个高安全性、实时性的操作系统,广泛应用于任务关键领域,例如电力、轨道交通、车载系统、工业控制和新能源等。它的加入让RK3568能够在保证系统实时性和安全性的同时,灵活处理复杂的任务场景。    在一般情况下,iTOP-RK3568的四个Cortex-A55核心通常运行Linux......