• 高并发面试:线程池的七大参数?手写一个线程池?


    线程池

    1. Callable接口的使用

    1. package com.yuxue.juc.threadPool;
    2. import java.util.concurrent.Callable;
    3. import java.util.concurrent.ExecutionException;
    4. import java.util.concurrent.FutureTask;
    5. /**
    6. * 多线程中,第三种获得多线程的方式
    7. * */
    8. public class CallableTest {
    9. public static void main(String[] args) throws ExecutionException, InterruptedException {
    10. //FutureTask(Callable<V> callable)
    11. FutureTask<Integer> futureTask = new FutureTask<>(new myThread());
    12. new Thread(futureTask, "AAA").start();
    13. //new Thread(futureTask, "BBB").start();//复用,直接取值,不要重启两个线程
    14. int a = 100;
    15. int b = 0;
    16. //b = futureTask.get();//要求获得Callable线程的计算结果,如果没有计算完成就要去强求,会导致堵塞,直到计算完成
    17. while (!futureTask.isDone()) {
    18. 当futureTask完成后取值
    19. b = futureTask.get();
    20. }
    21. System.out.println("===Result is:" + (a + b));
    22. }
    23. }
    24. class myThread implements Callable<Integer> {
    25. @Override
    26. public Integer call() throws Exception {
    27. System.out.println(Thread.currentThread().getName() + "\tget in the callable");
    28. Thread.sleep(5000);
    29. return 1024;
    30. }
    31. }

    两者区别:

    • Callable:有返回值,抛异常
    • Runnable:无返回值,不抛出异常

    2. 为什么要使用线程池

    1. 线程池做的工作主要是控制运行的线程的数量,处理过程中将任务放入队列,然后在线程创建后启动给这些任务,如果线程数量超过了最大数量,超出数量的线程排队等候,等其他线程执行完毕,再从队列中取出任务来执行
    2. 主要特点线程复用、控制最大并发数、管理线程减少创建和销毁线程上所花的时间以及系统资源的开销 => 减少内存开销,创建线程占用内存,创建线程需要时间,会延迟处理的请求;降低资源消耗,通过重复利用已创建的线程降低线程创建和销毁造成的消耗提高响应速度。当任务到达时,任务可以不需要等到线程创建就能立即执行提高线程的客观理性。线程是稀缺资源,如果无限制的创建,不仅会消耗系统资源,还会降低系统的稳定性,使用线程池可以进行统一的分配,调优和监控(根据系统承受能力,达到运行的最佳效果) => 避免无限创建线程引起的OutOfMemoryError【简称OOM】

    3. 线程池如何使用?

  • 相关阅读:
    MyBatis基础之自动映射、映射类型、文件注解双配置
    基于BP神经网络算法的性别识别
    算法题集:数学问题--数字黑洞(c/c++)
    LeetCode·32.最长有效括号·栈·动态规划
    SSL是什么?关于SSL和TLS的常见问题
    图的存储-链式前向星
    Java-GUI编程之处理位图
    极客日报:达摩院实现全球最大AI预训练模型;苹果3nm芯片或将2023年问世;微软官宣加入JCP计划
    华为机试 - 等和子数组最小和
    Monaco Editor教程(十八):使用api来完成某些键盘操作,格式化,查找,显示右侧菜单等。
  • 原文地址:https://blog.csdn.net/msbz7/article/details/126658985