多线程与并发,Java中介绍一下Thread类和Runnable接口的区别。

简介: 多线程与并发,Java中介绍一下Thread类和Runnable接口的区别。

Java中,有两种主要的方式来创建和管理线程:Thread类和Runnable接口。这两种方式在实现多线程时有一些不同之处。

Thread 类

  • Thread是一个类,你可以直接实例化它来创建一个新的线程。
  • 通过重写Thread类的run()方法,可以定义线程执行的任务。
  • 创建Thread对象后,可以通过调用start()方法来启动新线程。
  • 使用Thread类的一个潜在缺点是由于Java不支持多重继承,因此如果你希望一个类同时继承其他类并成为一个线程,这将无法实现。
class MyThread extends Thread {
   
    public void run() {
   
        // 线程任务代码
    }
}

public class Main {
   
    public static void main(String[] args) {
   
        MyThread thread = new MyThread();
        thread.start();
    }
}

Runnable 接口

  • Runnable是一个接口,你不能直接实例化它,而是需要创建一个新的类来实现这个接口。
  • 实现Runnable接口的类必须提供一个run()方法,该方法定义了线程要执行的任务。
  • 要启动一个基于Runnable接口的线程,你需要先创建一个Thread对象,然后将你的Runnable实例作为参数传递给Thread构造函数,并调用start()方法。
class MyRunnable implements Runnable {
   
    public void run() {
   
        // 线程任务代码
    }
}

public class Main {
   
    public static void main(String[] args) {
   
        Thread thread = new Thread(new MyRunnable());
        thread.start();
    }
}

区别与选择:

  1. 继承限制Thread类的方式受到Java单继承限制,如果一个类已经继承了另一个类,那么就不能再继承Thread类。而Runnable接口可以避免这个问题,因为它允许使用多态性(一个类可以实现多个接口)。

  2. 资源共享:使用Runnable接口的方式更容易实现资源共享,因为你可以创建一个包含所有共享数据的类,然后让多个线程实例共享这个类的实例。

  3. 灵活性:当任务逻辑需要修改或扩展时,使用Runnable接口可能更灵活,因为你只需要创建一个新的Runnable子类,而不是整个Thread子类。

  4. 可复用性:如果你的任务不需要访问任何特定于线程的信息,例如线程优先级等,那么使用Runnable接口可以使你的任务更容易被复用。这是因为Runnable只关注任务本身,而没有与线程相关的额外信息。

  5. 线程组Thread类提供了更多的控制线程的方法,如设置线程优先级、获取线程名称等。如果你需要这些功能,那么使用Thread类可能更为方便。

在实际编程中,通常建议使用Runnable接口来创建线程,因为它具有更好的灵活性和可复用性。但是,具体的选择取决于你的需求和设计决策。

相关文章
|
2月前
|
Java 程序员
Java社招面试题:& 和 && 的区别,HR的套路险些让我翻车!
小米,29岁程序员,分享了一次面试经历,详细解析了Java中&和&&的区别及应用场景,展示了扎实的基础知识和良好的应变能力,最终成功获得Offer。
91 14
|
1月前
|
Java
java中面向过程和面向对象区别?
java中面向过程和面向对象区别?
27 1
|
2月前
|
Java C# Python
线程等待(Thread Sleep)
线程等待是多线程编程中的一种同步机制,通过暂停当前线程的执行,让出CPU时间给其他线程。常用于需要程序暂停或等待其他线程完成操作的场景。不同语言中实现方式各异,如Java的`Thread.sleep(1000)`、C#的`Thread.Sleep(1000)`和Python的`time.sleep(1)`。使用时需注意避免死锁,并考虑其对程序响应性的影响。
|
20天前
|
Java 程序员 调度
【JavaEE】线程创建和终止,Thread类方法,变量捕获(7000字长文)
创建线程的五种方式,Thread常见方法(守护进程.setDaemon() ,isAlive),start和run方法的区别,如何提前终止一个线程,标志位,isinterrupted,变量捕获
|
20天前
|
安全 Java API
【JavaEE】多线程编程引入——认识Thread类
Thread类,Thread中的run方法,在编程中怎么调度多线程
|
2月前
|
存储 缓存 安全
java 中操作字符串都有哪些类,它们之间有什么区别
Java中操作字符串的类主要有String、StringBuilder和StringBuffer。String是不可变的,每次操作都会生成新对象;StringBuilder和StringBuffer都是可变的,但StringBuilder是非线程安全的,而StringBuffer是线程安全的,因此性能略低。
71 8
|
9天前
|
监控 Java
java异步判断线程池所有任务是否执行完
通过上述步骤,您可以在Java中实现异步判断线程池所有任务是否执行完毕。这种方法使用了 `CompletionService`来监控任务的完成情况,并通过一个独立线程异步检查所有任务的执行状态。这种设计不仅简洁高效,还能确保在大量任务处理时程序的稳定性和可维护性。希望本文能为您的开发工作提供实用的指导和帮助。
54 17
|
20天前
|
Java
Java—多线程实现生产消费者
本文介绍了多线程实现生产消费者模式的三个版本。Version1包含四个类:`Producer`(生产者)、`Consumer`(消费者)、`Resource`(公共资源)和`TestMain`(测试类)。通过`synchronized`和`wait/notify`机制控制线程同步,但存在多个生产者或消费者时可能出现多次生产和消费的问题。 Version2将`if`改为`while`,解决了多次生产和消费的问题,但仍可能因`notify()`随机唤醒线程而导致死锁。因此,引入了`notifyAll()`来唤醒所有等待线程,但这会带来性能问题。
Java—多线程实现生产消费者
|
5天前
|
缓存 安全 算法
Java 多线程 面试题
Java 多线程 相关基础面试题
|
22天前
|
安全 Java Kotlin
Java多线程——synchronized、volatile 保障可见性
Java多线程中,`synchronized` 和 `volatile` 关键字用于保障可见性。`synchronized` 保证原子性、可见性和有序性,通过锁机制确保线程安全;`volatile` 仅保证可见性和有序性,不保证原子性。代码示例展示了如何使用 `synchronized` 和 `volatile` 解决主线程无法感知子线程修改共享变量的问题。总结:`volatile` 确保不同线程对共享变量操作的可见性,使一个线程修改后,其他线程能立即看到最新值。