当前位置:首页 > Java

Java如何创建多线程

2026-03-04 08:07:13Java

创建多线程的几种方法

Java中创建多线程主要有以下三种方式:继承Thread类、实现Runnable接口、实现Callable接口并结合ExecutorService使用。

继承Thread类

通过继承Thread类并重写run()方法可以创建线程。这种方式简单直接,但Java不支持多重继承,因此如果类已经继承了其他类,就无法使用这种方法。

class MyThread extends Thread {
    @Override
    public void run() {
        System.out.println("Thread running by extending Thread class");
    }
}

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

实现Runnable接口

实现Runnable接口是更灵活的方式,因为Java支持多重接口实现。需要实现run()方法,并将Runnable实例传递给Thread类的构造函数。

Java如何创建多线程

class MyRunnable implements Runnable {
    @Override
    public void run() {
        System.out.println("Thread running by implementing Runnable interface");
    }
}

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

实现Callable接口

Callable接口允许线程返回结果或抛出异常,通常与ExecutorService一起使用。Callablecall()方法可以返回泛型类型的结果。

import java.util.concurrent.*;

class MyCallable implements Callable<String> {
    @Override
    public String call() throws Exception {
        return "Thread running by implementing Callable interface";
    }
}

public class Main {
    public static void main(String[] args) throws ExecutionException, InterruptedException {
        ExecutorService executor = Executors.newSingleThreadExecutor();
        Future<String> future = executor.submit(new MyCallable());
        System.out.println(future.get());
        executor.shutdown();
    }
}

线程池的使用

Java提供了ExecutorServiceExecutors类来管理线程池,避免频繁创建和销毁线程的开销。

Java如何创建多线程

import java.util.concurrent.*;

public class Main {
    public static void main(String[] args) {
        ExecutorService executor = Executors.newFixedThreadPool(5);
        for (int i = 0; i < 10; i++) {
            Runnable worker = new WorkerThread("Task " + i);
            executor.execute(worker);
        }
        executor.shutdown();
    }
}

class WorkerThread implements Runnable {
    private String taskName;

    public WorkerThread(String taskName) {
        this.taskName = taskName;
    }

    @Override
    public void run() {
        System.out.println(Thread.currentThread().getName() + " executing " + taskName);
    }
}

线程同步

多线程环境下共享资源可能导致数据不一致,可以使用synchronized关键字或Lock接口实现线程同步。

使用synchronized方法

class Counter {
    private int count = 0;

    public synchronized void increment() {
        count++;
    }

    public int getCount() {
        return count;
    }
}

public class Main {
    public static void main(String[] args) throws InterruptedException {
        Counter counter = new Counter();
        Thread t1 = new Thread(() -> {
            for (int i = 0; i < 1000; i++) {
                counter.increment();
            }
        });
        Thread t2 = new Thread(() -> {
            for (int i = 0; i < 1000; i++) {
                counter.increment();
            }
        });
        t1.start();
        t2.start();
        t1.join();
        t2.join();
        System.out.println("Count: " + counter.getCount());
    }
}

使用Lock接口

import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

class Counter {
    private int count = 0;
    private Lock lock = new ReentrantLock();

    public void increment() {
        lock.lock();
        try {
            count++;
        } finally {
            lock.unlock();
        }
    }

    public int getCount() {
        return count;
    }
}

线程间通信

wait()notify()notifyAll()方法用于线程间通信,必须在同步块或同步方法中调用。

class SharedResource {
    private boolean flag = false;

    public synchronized void produce() {
        while (flag) {
            try {
                wait();
            } catch (InterruptedException e) {
                Thread.currentThread().interrupt();
            }
        }
        flag = true;
        System.out.println("Produced");
        notify();
    }

    public synchronized void consume() {
        while (!flag) {
            try {
                wait();
            } catch (InterruptedException e) {
                Thread.currentThread().interrupt();
            }
        }
        flag = false;
        System.out.println("Consumed");
        notify();
    }
}

public class Main {
    public static void main(String[] args) {
        SharedResource resource = new SharedResource();
        Thread producer = new Thread(resource::produce);
        Thread consumer = new Thread(resource::consume);
        producer.start();
        consumer.start();
    }
}

标签: 多线程Java
分享给朋友:

相关文章

php怎么实现多线程

php怎么实现多线程

PHP 实现多线程的方法 PHP 本身是单线程语言,但可以通过扩展或特定方式模拟多线程行为。以下是几种常见实现方式: 使用 PCNTL 扩展(进程控制) PCNTL 是 PHP 的进程控制扩展,允许…

Java如何换行

Java如何换行

在Java中换行的几种方法 在Java中,换行可以通过多种方式实现,具体取决于使用场景和需求。以下是几种常见的换行方法: 使用\n转义字符 \n是换行符的转义字符,可以在字符串中直接使用: Sy…

java中如何实现多线程

java中如何实现多线程

实现多线程的三种核心方法 继承Thread类 通过继承Thread类并重写run()方法定义线程任务。创建子类实例后调用start()方法启动线程。 class MyThread extends…

Java 如何初始化

Java 如何初始化

初始化基本数据类型 基本数据类型(如 int、double、boolean 等)可以直接赋值初始化: int num = 10; double price = 29.99; boolean is…

java多线程如何实现

java多线程如何实现

多线程的基本实现方式 Java中实现多线程主要有两种方式:继承Thread类或实现Runnable接口。通过重写run()方法定义线程任务。 继承Thread类 class MyThread ex…

Java如何添加事件

Java如何添加事件

添加事件的基本方法 在Java中,事件处理通常涉及事件源、事件监听器和事件对象。以下是实现事件处理的基本步骤: 定义事件监听器接口 事件监听器是一个接口,定义了处理特定事件的方法。例如,Action…