在Java中,可以使用java.lang.Thread
类或者java.util.concurrent
包中的ExecutorService
和Future
等接口来创建和管理多线程。这里我将向您展示如何使用这两种方法在命令行(cmd)上运行多线程Java程序。
方法1:使用Thread类
- 首先,创建一个名为
MyThread.java
的文件,然后编写以下代码:
public class MyThread extends Thread { public void run() { for (int i = 0; i < 5; i++) { System.out.println(Thread.currentThread().getName() + ":" + i); } } }
- 编译Java文件:
javac MyThread.java
- 在命令行中,使用
-cp
选项指定类路径,然后运行编译后的MyThread
类:
java -cp . MyThread MyThread1 MyThread2 MyThread3
这将创建并启动四个线程,每个线程打印出它的名称和一个循环计数器。
方法2:使用ExecutorService和Future
- 创建一个名为
MyThreadPool.java
的文件,然后编写以下代码:
import java.util.concurrent.*; public class MyThreadPool { public static void main(String[] args) { int numberOfThreads = 4; ExecutorService executorService = Executors.newFixedThreadPool(numberOfThreads); for (int i = 0; i < numberOfThreads; i++) { executorService.submit(new MyRunnable(i)); } executorService.shutdown(); } } class MyRunnable implements Runnable { private int taskNumber; public MyRunnable(int taskNumber) { this.taskNumber = taskNumber; } @Override public void run() { for (int i = 0; i < 5; i++) { System.out.println("Task " + taskNumber + ":" + i); } } }
- 编译Java文件:
javac MyThreadPool.java
- 在命令行中,使用
-cp
选项指定类路径,然后运行编译后的MyThreadPool
类:
java -cp . MyThreadPool
这将创建一个固定大小的线程池,提交四个任务到线程池,每个任务打印出它的任务编号和一个循环计数器。完成后,线程池将关闭。