Java多线程编程是指在一个Java程序中同时运行多个线程,每个线程都可以执行不同的任务。多线程编程可以显著提高程序的性能和响应能力,尤其是在处理大量并发请求或执行需要等待的操作(如I/O操作)时。
在实际开发场景中,多线程编程常用于以下情况:
- 图形用户界面(GUI):如Swing或JavaFX,通过多线程可以保持界面的流畅性,同时执行后台任务。
- 网络编程:服务器需要同时处理多个客户端的请求,每个请求都可以在一个单独的线程中处理。
- 数据处理:当需要处理大量数据时,可以使用多线程将数据分成多个部分并行处理。
- 并行计算:在高性能计算中,利用多线程可以加速计算过程。
Java提供了几种实现多线程的方式:
- 继承Thread类:
public class MyThread extends Thread {
@Override
public void run() {
System.out.println("MyThread is running...");
}
public static void main(String[] args) {
MyThread thread = new MyThread();
thread.start();
}
}
- 实现Runnable接口:这种方式更为推荐,因为Java不支持多重继承,但可以实现多个接口。
public class MyRunnable implements Runnable {
@Override
public void run() {
System.out.println("MyRunnable is running...");
}
public static void main(String[] args) {
Thread thread = new Thread(new MyRunnable());
thread.start();
}
}
- 使用Callable和Future(结合ExecutorService):这种方式允许线程返回结果,并可以处理异常。
import java.util.concurrent.*;
public class MyCallable implements Callable<String> {
@Override
public String call() throws Exception {
return "MyCallable is running...";
}
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多线程编程的几种主要方法:
- start():启动线程,调用线程的run()方法。
- run():线程要执行的任务,在线程启动时由JVM调用。
- join():等待线程结束。调用一个线程的join()方法会使当前线程等待该线程结束。
- sleep(long millis):使当前线程休眠指定的毫秒数。
- interrupt():中断线程。但中断并不会立即停止线程,而是设置线程的中断状态。线程需要定期检查这个状态,并决定是否停止执行。
- isAlive():检查线程是否存活。
- setPriority(int newPriority) 和 getPriority():设置和获取线程的优先级。注意,这并不意味着优先级高的线程一定会先执行。
- yield():让当前线程放弃CPU资源,让其他线程有机会执行。但这只是提示性的,不一定保证立即让出CPU。
- wait() 和 notify()/notifyAll():用于线程间的通信和同步。这些方法只能在同步代码块或同步方法中调用。