先看看java线程池的应用:通过工具类来构建一个线程池
ExecutorService executorService =Executors.newFixedThreadPool(4);
这里的 ExecutorService 就是一个线程池,通过线程池执行一个任务(Runnale 或者callbale)
data:image/s3,"s3://crabby-images/16e30/16e30f8630d85687ce50ddeb1853b8a62f736c5d" alt=""
data:image/s3,"s3://crabby-images/e0fb5/e0fb5a7a3542d43ad8fa88d9a1f11c9bdd15f64c" alt=""
在线程池中execute这个方法只能够执行Rannale的任务,执行完以后没有返回值,submit 方法可以执行Runnable he Callbale 任务,Callbale 任务执行完以后可以返回一个返回值
第一步先来看看线程池是怎么实现的:
data:image/s3,"s3://crabby-images/08c40/08c4050e08fb27556356fe001242577737b6914c" alt=""
data:image/s3,"s3://crabby-images/16840/16840d9fb879bee9bb04864097259a3e338fbec9" alt=""
现在可以开始分析线程池的的任务的提交了:
data:image/s3,"s3://crabby-images/5a7f4/5a7f4aeb3ef9c6dd00b4dcd3e83e27b758c999fe" alt=""
data:image/s3,"s3://crabby-images/c9efa/c9efabc78592b04f7bfbfe9449b65b2bd696031c" alt=""
这里可以看看线程池的集成结构:
data:image/s3,"s3://crabby-images/75c32/75c32096aa56d50c762b5756858446004cfaffdf" alt=""
线程池通过一个int的高三位表示线程池的状态 低29位表示线程池中运行的线程数
即
data:image/s3,"s3://crabby-images/8ae7c/8ae7cbda6b9a47907179d03e0c1d238bc49f9766" alt=""
通过上面执行任务的两个方法,我们会发现,这两个方法分别在不同的借口中,execute这个方法在最顶层的借口Executor中,而submit这个方法对应的在ExecutorService中.
data:image/s3,"s3://crabby-images/5aac3/5aac39725f14fe747fbb18a7e8cea41fb505c2ce" alt=""
data:image/s3,"s3://crabby-images/68289/6828930dd5e5070847980de836243ed77bdee466" alt=""
下面分析关键的代码,这段代码是线程池实现的真真关键的部分:addWorker()这个方法是一个非常关键的代码
data:image/s3,"s3://crabby-images/ee3d6/ee3d69a061d5a4c5ba8a8823de0a62a475dfb093" alt=""
data:image/s3,"s3://crabby-images/0a31d/0a31d2d9fc3f1596e9509d81397275ca6de3e4a1" alt=""
进入new Worker中发现worker是一个Runnable接口的对象
data:image/s3,"s3://crabby-images/ae3dd/ae3ddfbefce65bf76058d9b4c894f4579a8642b6" alt=""
data:image/s3,"s3://crabby-images/ed9a2/ed9a2c02aab72a8ea005a8e5e3896415197fc03b" alt=""
所以当worker对象添加成功以后,启动这个worker对象的线程的时候,执行的是worker对象中run方法
data:image/s3,"s3://crabby-images/8fdd5/8fdd51da778dd94c959bbd93e551fb4b2f7038ac" alt=""
data:image/s3,"s3://crabby-images/ca945/ca9458f989ba57ebfdc61a5cc0e345502daa1fd0" alt=""
下面是getTask()方法的代码,工作队列中有任务这个while 循环就不会跳出当前线程一直在自旋执行任务
data:image/s3,"s3://crabby-images/082b1/082b109e3dd6300f36ab804e10e797e7338e17a4" alt=""
当线程池中的线程出现异常的时候。执行退出线程的流程:
先移除出现异常的线程,然后在添加一个新的线程。和timer不一样。timer只有一个线程,如果出现日常就没有线程执行任务了
data:image/s3,"s3://crabby-images/efa7d/efa7dd873319d6c0d0003fc38411dde31f67235d" alt=""
submit()方法的分析;
data:image/s3,"s3://crabby-images/29ff8/29ff87e433322f406c74e898613db3d3c0726288" alt=""
data:image/s3,"s3://crabby-images/e33e4/e33e4034a992468ffd6b0be5c7355b14f1407ff3" alt=""
data:image/s3,"s3://crabby-images/6fc33/6fc3311987e269d6cce7326ff8862a1e8558dc56" alt=""
data:image/s3,"s3://crabby-images/4bc1a/4bc1aa79663466d3ab298ae8b0b79111b9cf2f25" alt=""
shutdown()方法:
data:image/s3,"s3://crabby-images/51bea/51bea4aee1840ccfaf4d352153075814be4dd8fe" alt=""
data:image/s3,"s3://crabby-images/dbdc7/dbdc76490ce4c92d9850007a860c9a7b7a7f2267" alt=""
网友评论