- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
执行绪的状态
* 常用的ThreadGroup方法 ThreadGroup的方法 說明 final int getMaxPriority() 取得群組中最大的優先權值。 final String getName() 取得群組名稱。 final ThreadGroup getParent() 取得父群組。 final void interrupt() 中斷群組中所有的執行緒。 final void setMaxPriority(int pri) 設定群組的最高優先權值為pri。 執行緒群組 * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * Ch14 執行緒(II) 物件導向系統實務 * 本章大綱 本章內容包含課本第16章(電子書): 行程與執行緒 Thread類別 Runnable介面 執行緒的狀態 執行緒控制 執行緒的優先權 多執行緒的同步 執行緒群組 * 執行緒的狀態包括起始狀態(Prepared)、可執行狀態(Ready)、正執行狀態(Running)、等待狀態(Waiting)及死亡狀態(Dead)。 執行緒的狀態 * 起始狀態(Prepared):當我們使用new關鍵字建立一個Thread物件後,未呼叫其start()方法。 可執行狀態(Ready):呼叫start()方法後,正等著排程者(thread scheduler)安排執行。 正執行狀態(Running):執行緒正在使用CPU的狀態。亦即進入執行run()方法 等待狀態(Waiting):在執行run()方法的期間,等待某事件的發生才繼續的狀態,例如呼叫sleep()方法。 死亡狀態(Dead):執行緒執行完成run()方法後即進入死亡狀態。進入死亡狀態的執行緒不能被重新啟動。 執行緒的狀態 * isAlive()方法測試執行緒狀態 起始狀態: isAlive()為false 可執行狀態:isAlive()為true 正執行狀態:isAlive()為true 等待狀態:isAlive()為true 死亡狀態:isAlive()為flase * 範例1:利用isAlive()方法來測試執行緒狀態 class Ch06_01 { public static void main(String [] args) { AliveTest at = new AliveTest(); Thread mt = new Thread( at ); System.out.println(at.state + mt.isAlive()); //列出執行緒狀態 mt.start(); while(mt.isAlive()) { try { Thread.sleep(10); } catch (Exception e) {} System.out.println(at.state + mt.isAlive()); } } } //AliveTest類別定義,實作Runnable介面 class AliveTest implements Runnable { String state = 起始狀態 ; public void run() //執行緒方法 { state = 可執行狀態 ; for(long n=0, m = 0; n1000000; n++) //留在可執行狀態的迴圈 m += n; try { state = 等待狀態 ; Thread.sleep(150);//暫停150毫秒 } catch (Exception e) {} state = 死亡狀態 ; } } * 執行緒控制—yield()放棄該次CPU的使用機會 為了避免CPU被獨佔,可以使用yield()方法讓某個執行緒進入Ready狀態,而暫時先讓出CPU。 呼叫高優先權執行緒的yield()方法,可以讓低優先權執行緒有較多的機會使用到CPU,以避免低優先權執行緒處於挨餓狀態(starvation)。 * 執行緒控制--等待狀態 執行sleep()方法:暫停執行緒一段時間。 執行suspend()方法:沒有時間限制地暫停執行緒,可呼叫resume()方法回到Ready狀態。(suspend
您可能关注的文档
最近下载
- 北师大版八年级上册数学 第5章 二元一次方程 问题解决策略:逐步确定 教案.docx VIP
- 一年级上册数学第一单元试卷.doc VIP
- 地震数据分析软件:SeisComP二次开发_地震监测系统部署与维护.docx VIP
- 小红书种草营销师模拟试题及答案.docx VIP
- 音乐人吉他课.pptx VIP
- 隧道紧急停车带专项施工方案 - 生产安全.docx VIP
- 北师版八年级上册数学精品教学课件 第五章 二元一次方程组 ☆问题解决策略_逐步确定 (2).ppt VIP
- 北师版八年级上册数学精品教学课件 第五章 二元一次方程组 ☆问题解决策略_逐步确定.ppt VIP
- 问题解决策略:逐步确定 2025-2026学年北师大版数学八年级上册.pptx VIP
- 音乐人吉他课.docx VIP
文档评论(0)