验证码: 看不清楚,换一张 查询 注册会员,免验证
  • {{ basic.site_slogan }}
  • 打开微信扫一扫,
    您还可以在这里找到我们哟

    关注我们

Java多线程中如何创建线程池

阅读:405 来源:乙速云 作者:代码code

Java多线程中如何创建线程池

在Java中,可以使用java.util.concurrent.Executors类来创建线程池。以下是几种常见的线程池类型及其创建方法:

  1. 固定大小的线程池(Fixed Thread Pool):
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class FixedThreadPoolExample {
    public static void main(String[] args) {
        int numberOfThreads = 5;
        ExecutorService executorService = Executors.newFixedThreadPool(numberOfThreads);

        for (int i = 0; i < 10; i++) {
            Runnable worker = new WorkerThread("" + i);
            executorService.execute(worker);
        }

        executorService.shutdown();
        while (!executorService.isTerminated()) {
        }
        System.out.println("Finished all threads");
    }
}

class WorkerThread implements Runnable {
    private String command;

    public WorkerThread(String s) {
        this.command = s;
    }

    @Override
    public void run() {
        System.out.println(Thread.currentThread().getName() + " Start. Command = " + command);
        processCommand();
        System.out.println(Thread.currentThread().getName() + " End.");
    }

    private void processCommand() {
        try {
            Thread.sleep(500);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}
  1. 单线程的线程池(Single Thread Executor):
ExecutorService singleThreadExecutor = Executors.newSingleThreadExecutor();
  1. 可缓存的线程池(Cached Thread Pool):
ExecutorService cachedThreadPool = Executors.newCachedThreadPool();
  1. 定时任务线程池(Scheduled Thread Pool):
import java.util.concurrent.ScheduledExecutorService;
import java.util.concurrent.Executors;

ScheduledExecutorService scheduledExecutorService = Executors.newScheduledThreadPool(5);
  1. 单线程定时任务线程池(Single Thread Scheduled Executor):
ScheduledExecutorService singleThreadScheduledExecutor = Executors.newSingleThreadScheduledExecutor();

创建线程池后,可以使用execute(Runnable)方法提交任务。当不再需要线程池时,应调用shutdown()方法来关闭线程池。如果需要等待所有已提交的任务完成,可以调用awaitTermination(long timeout, TimeUnit unit)方法。

注意:在实际应用中,应根据具体需求选择合适的线程池类型,并合理配置线程池参数,以达到最佳性能。

分享到:
*特别声明:以上内容来自于网络收集,著作权属原作者所有,如有侵权,请联系我们: hlamps#outlook.com (#换成@)。
相关文章
{{ v.title }}
{{ v.description||(cleanHtml(v.content)).substr(0,100)+'···' }}
你可能感兴趣
推荐阅读 更多>