电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Java簡單實現線程池

瀏覽:49日期:2022-08-13 15:14:24

本文實例為大家分享了Java簡單實現線程池的具體代碼,供大家參考,具體內容如下

一、線程池

線程池是一種緩沖提高效率的技術。相當于一個池子,里面存放大量已經創建好的線程,當有一個任務需要處理時, 可以直接從池子里面取一個線程去執行它。 包括內存池,很多緩沖的技術都是采用這種技術。 其實理解起來很簡答!

為什么需要線程池,這種池的技術?

1.1 減少開辟資源和銷毀資源帶來的損耗。

開辟線程,申請內存(具體的可以看C語言中malloc底層實現原理),銷毀線程、釋放內存資源等一些操作都是有時間消耗的。因此一開始開辟大量的資源進行管理,需要使用時從池中取一個去使用, 使用完畢后再放回池中管理, 這樣可以避免資源開辟和銷毀帶來的時間損耗。

1.2 提高響應。

用戶來了一個請求, 能夠立刻從開辟好的線程池中取一個線程去處理執行。 提高響應效率,提高用戶體驗。

1.3 有效管理資源

管理資源統一開辟和銷毀, 監控線程狀態和調優

二、線程池分析

對于線程池的實現我們劃分為2個部分

1、線程安全的任務隊列(采用隊列,不過是線程安全的而已),保證工作線程在去任務時不會發生沖突(重復取同一個任務處理,二次執行或者多次的問題)。2、對工作線程的監管(采用是List管理工作線程),方便線程的銷毀和管理。

線程池處理邏輯:

1、每當添加一個任務,就會從線程池中取一個工作線程去處理執行它。2、沒有任務處理時, 工作線程應該處于阻塞狀態等待任務到來, 不會競爭占用CPU資源3、線程池相當于生產-消費模型, 只不過生產線程的中生產任務不同罷了。

3、主線程相當于監管線程,最終負責工作線程的銷毀。

三、線程池實現

1、 工作線程Worker

1.1、工作線程負責從阻塞任務隊列中取出任務執行。由于存在很多個線程對同一個隊列操作,因此這個任務隊列一定得是線程安全的(采用BlockingQueue接口, 這是GUC提供的,線程安全)1.2、工作線程的創建方式屬于線程創建的方式之一。1.3、每個工作線程都維護一個阻塞任務隊列。1.4、線程的執行方法run()中,以線程的中斷狀態為循環判斷條件(方便線程銷毀, 只要將工作線程的中斷狀態置為true即可釋放工作線程)其次就是BlockingQueue接口提供的take()方法。

Java簡單實現線程池

該方法在隊列沒有元素時處于阻塞狀態,直接取到元素,這樣就解決了沒有任務工作線程處于阻塞狀態,不會搶占CPU

//實現工作線程 - 工作線程中維護了公有的任務隊列(阻塞), 工作線程的執行邏輯。 循環取隊列中的任務去執行處理。class Worker extends Thread { //阻塞任務隊列 - 可以保證多個線程對隊列操作, 線程安全 private BlockingQueue<Runnable> queue = null; //每個工作線程都會有一個阻塞隊列,這個隊列中保存了所有的任務 public Worker(BlockingQueue<Runnable> queue, int id) {this.queue = queue; // Thread.currentThread().setName('郝夢武' + id + '號工作線程'); }//工作線程執行內容 @Override public void run() {//每個線程通過isInterrupted()判斷線程異常狀態。try { while (!Thread.currentThread().isInterrupted()) {//如果線程正常, 返回false, 出現異常, 返回true, 該狀態默認為falseRunnable command = queue.take(); //如果隊列為空, take會讓線程阻塞System.out.println(Thread.currentThread().getName() + '正在處理任務' + command.hashCode());command.run(); }}catch(InterruptedException e) { System.out.println(Thread.currentThread().getName() + '被中止了');// e.printStackTrace(); //不需要拋出異常} }}

2、線程池對象MyThreadPool

1、創建工作線程并管理,添加任務。2、銷毀所有工作線程

//線程池 - 維護很多個線程, 當來一個任務時, 從線程池中獲取一個線程去處理執行。//好處: 防止線程頻繁開辟和銷毀帶來的性能損耗class MyThreadPool { //創建任務線程安全的隊列, 保證多個線程對這個隊列操作時是線程安全的 private BlockingQueue<Runnable> queue = new LinkedBlockingQueue<>(); //線程管理列表 - 這個列表保存了所有線程對象的引用, 方便后續的管理 private List<Worker> Wokers = new ArrayList<>(); private final static int maxWorkerCount = 10; //線程池最大允許的個數 //execute方法 public void execute(Runnable command) throws InterruptedException {if(Wokers.size() < maxWorkerCount) { //創建一個新的工作線程 Worker worker = new Worker(queue, Wokers.size()); //創建工作線程 worker.start(); //創建的工程線程啟動 Wokers.add(worker); //添加到管理列表中}queue.put(command); //添加任務到線程安全的隊列中 } //銷毀所有線程 - 將每個線程中狀態置為中斷狀態方法, 并且 public void shutDown() throws InterruptedException {for(Worker worker : Wokers) { worker.interrupt(); //將線程的狀態置為中斷, 調用isInterruptd()返回值為true}//并且讓主線程join阻塞等待所有工作線程for(Worker worker : Wokers) { worker.join(); //join方法可以讓調用的線程處于阻塞狀態, 知道等待的線程結束完畢之后就會恢復}//執行到這塊, 代表所有的線程銷毀完畢System.out.println('所有工作線程銷毀完畢!'); }}

3、測試代碼

class MyRunnable implements Runnable { private int num; MyRunnable(int num) {this.num = num; } @Override public void run() {System.out.println('正在執行任務: ' + num); }}public static void main(String[] args) throws InterruptedException { MyThreadPool myThreadPool = new MyThreadPool(); for(int i = 0; i < 1000; i++) { myThreadPool.execute(new MyRunnable(i + 1)); } Thread.sleep(2000); //主線程休眠2s myThreadPool.shutDown(); //銷毀所有工作線程 System.out.println('線程池已經被銷毀了'); }

4、測試結果

Java簡單實現線程池

Java簡單實現線程池

總結:

以上的代碼只是簡單模擬實現了線程池。不僅僅是線程池,內容池,還有很多池的應用場景。池的技術雖然能夠起到快速響應的特點,但是還是存在問題。第一點: 池需要在一開始創建很多資源, 這和我們機器內存大小有關系。第二點: 池中的線程過多,但是任務過少,導致很多線程浪費掉, 因此池中開辟多大的資源需要根據實際情況而言。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Java
相關文章:
主站蜘蛛池模板: 防弹玻璃厂家_防爆炸玻璃_电磁屏蔽玻璃-四川大硅特玻科技有限公司 | 回收二手冲床_金丰旧冲床回收_协易冲床回收 - 大鑫机械设备 | 真空乳化机-灌装封尾机-首页-温州精灌 | 废气处理_废气处理设备_工业废气处理_江苏龙泰环保设备制造有限公司 | 滁州高低温冲击试验箱厂家_安徽高低温试验箱价格|安徽希尔伯特 | 长沙印刷厂-包装印刷-画册印刷厂家-湖南省日大彩色印务有限公司 青州搬家公司电话_青州搬家公司哪家好「鸿喜」青州搬家 | 石油/泥浆/不锈钢防腐/砂泵/抽砂泵/砂砾泵/吸砂泵/压滤机泵 - 专业石油环保专用泵厂家 | 膜片万向弹性联轴器-冲压铸造模具「沧州昌运模具」 | 户外环保不锈钢垃圾桶_标识标牌制作_园林公园椅厂家_花箱定制-北京汇众环艺 | 微型驱动系统解决方案-深圳市兆威机电股份有限公司 | 反渗透阻垢剂-缓蚀阻垢剂厂家-循环水处理药剂-山东鲁东环保科技有限公司 | 不锈钢钢格栅板_热浸锌钢格板_镀锌钢格栅板_钢格栅盖板-格美瑞 | 双相钢_双相不锈钢_双相钢圆钢棒_双相不锈钢报价「海新双相钢」 双能x射线骨密度检测仪_dxa骨密度仪_双能x线骨密度仪_品牌厂家【品源医疗】 | 智能交通网_智能交通系统_ITS_交通监控_卫星导航_智能交通行业 | 水环真空泵厂家,2bv真空泵,2be真空泵-淄博真空设备厂 | 低浓度恒温恒湿称量系统,强光光照培养箱-上海三腾仪器有限公司 | 电缆隧道在线监测-智慧配电站房-升压站在线监测-江苏久创电气科技有限公司 | 长沙广告公司|长沙广告制作设计|长沙led灯箱招牌制作找望城湖南锦蓝广告装饰工程有限公司 | 创绿家招商加盟网-除甲醛加盟-甲醛治理加盟-室内除甲醛加盟-创绿家招商官网 | 风淋室生产厂家报价_传递窗|送风口|臭氧机|FFU-山东盛之源净化设备 | 扒渣机,铁水扒渣机,钢水扒渣机,铁水捞渣机,钢水捞渣机-烟台盛利达工程技术有限公司 | 聚氨酯复合板保温板厂家_廊坊华宇创新科技有限公司 | 专业生产动态配料系统_饲料配料系统_化肥配料系统等配料系统-郑州鑫晟重工机械有限公司 | 雨燕360体育免费直播_雨燕360免费NBA直播_NBA篮球高清直播无插件-雨燕360体育直播 | 智能垃圾箱|垃圾房|垃圾分类亭|垃圾分类箱专业生产厂家定做-宿迁市传宇环保设备有限公司 | 塑料异型材_PVC异型材_封边条生产厂家_PC灯罩_防撞扶手_医院扶手价格_东莞市怡美塑胶制品有限公司 | 阳光模拟试验箱_高低温试验箱_高低温冲击试验箱_快速温变试验箱|东莞市赛思检测设备有限公司 | 软膜天花_软膜灯箱_首选乐创品牌_一站式天花软膜材料供应商! | 大型冰雕-景区冰雕展制作公司,3D创意设计源头厂家-[赛北冰雕] | 工业机械三维动画制作 环保设备原理三维演示动画 自动化装配产线三维动画制作公司-南京燃动数字 聚合氯化铝_喷雾聚氯化铝_聚合氯化铝铁厂家_郑州亿升化工有限公司 | 动物麻醉机-数显脑立体定位仪-北京易则佳科技有限公司 | 3d打印服务,3d打印汽车,三维扫描,硅胶复模,手板,快速模具,深圳市精速三维打印科技有限公司 | 北京公司注册_代理记账_代办商标注册工商执照-企力宝 | 雨水收集系统厂家-雨水收集利用-模块雨水收集池-徐州博智环保科技有限公司 | 蓄电池在线监测系统|SF6在线监控泄露报警系统-武汉中电通电力设备有限公司 | 破碎机锤头_合金耐磨锤头_郑州宇耐机械工程技术有限公司 | 砖机托板价格|免烧砖托板|空心砖托板厂家_山东宏升砖机托板厂 | 塑料托盘厂家直销-吹塑托盘生产厂家-力库塑业【官网】 | ICP备案查询_APP备案查询_小程序备案查询 - 备案巴巴 | 欧美日韩国产一区二区三区不_久久久久国产精品无码不卡_亚洲欧洲美洲无码精品AV_精品一区美女视频_日韩黄色性爱一级视频_日本五十路人妻斩_国产99视频免费精品是看4_亚洲中文字幕无码一二三四区_国产小萍萍挤奶喷奶水_亚洲另类精品无码在线一区 | 智慧物联网行业一站式解决方案提供商-北京东成基业 |