当前位置:首页 > 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类的构造函数。

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类来管理线程池,避免频繁创建和销毁线程的开销。

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如何创建多线程

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

相关文章

vue怎么实现多线程

vue怎么实现多线程

在Vue中实现多线程通常需要借助Web Workers或第三方库,因为Vue本身是前端框架,不直接提供多线程能力。以下是具体实现方法: 使用Web Workers Web Workers是浏览器提供…

php怎么实现多线程

php怎么实现多线程

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

js 实现多线程

js 实现多线程

实现多线程的方式 在JavaScript中,由于语言本身的单线程特性,无法直接实现多线程。但可以通过以下方式模拟或利用多线程的能力: Web Workers Web Workers是浏览器提供的AP…

Java如何换行

Java如何换行

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

Java如何实现异步处理

Java如何实现异步处理

Java实现异步处理的方法 Java提供了多种方式实现异步处理,以下是几种常见的方法: 使用CompletableFuture CompletableFuture是Java 8引入的异步编程工具,支…

如何实现java多线程

如何实现java多线程

实现 Java 多线程的方法 Java 提供了多种实现多线程的方式,以下是常见的几种方法: 继承 Thread 类 通过继承 Thread 类并重写 run() 方法可以实现多线程。创建一个新的类继…