我爱java系列---线程池的原理

Posted 少年攻城狮

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了我爱java系列---线程池的原理相关的知识,希望对你有一定的参考价值。

一、线程是不是越多越好?

造卡车(线程)要不要时间? 一次性使用,用完了得销毁,销毁要不要耗时间?
➢ 1、线程在java中是一 个对象, 每一个java线程都需要一 个操作系统线程支持。线程创建、销毁需要时间。
  如果创建时间+销毁时间>执行任务时间就很不合算。
➢ 2、java对象占用堆内存,操作系统线程占用系统内存,根据jvm规范,一个线程默认最大栈大小1M,这个栈
  空间是需要从系统内存中分配的。
  线程过多,会消耗很多的内存。
◆造很多的卡车,得需要空间来放它们,会不会造成内存紧张?
➢ 3、操作系统需要频繁切换线程上下文(大家都想被运行),影响性能。

二、如何正确使用多线程?(线程池)

➢ 多线程目的: 充分利用cpu并发做事(多做事)

➢ 线程的本质: 将代码送给cpu执行

➢ 用合适数量的卡车不断运送代码即可。

➢ 这合适数量的线程就构成了一个池。

➢  如果有任务要执行,就放入池中,池中的一个线程把任务运送到cpu中执行。

三、线程池工作原理

 

四、手写线程池步骤

1.任务用什么表示?

 

Runnable:无返回值,只负责执行。

Callable:1.有返回值,返回值用FutureTask对象接收,取的时候直接get;

      2.并且可以抛异常。

2.仓库用什么表示?

 

 3.代码示范(待完善)

 

4.如何确定合适数量的线程?

遇到这个问题,不要急于回答,先反问:你的服务器的最大大小是多少?

参考:

 

 

 

 

以上是关于我爱java系列---线程池的原理的主要内容,如果未能解决你的问题,请参考以下文章

Java多线程系列:Java线程池的使用方式,及核心运行原理

Java多线程系列:Java线程池的使用方式,及核心运行原理

Java多线程系列--“JUC线程池”02之 线程池原理

Java并发系列终结篇:彻底搞懂Java线程池的工作原理

Java多线程系列--“JUC线程池”02之 线程池原理

Java并发系列终结篇:学校门口保安小王,这次彻底搞懂了Java线程池的工作原理