Java進階(7)-并發(fā)(多線程基本概念)-創(chuàng)新互聯(lián)

一、中斷
interrupt方法只改變目標線程的中斷狀態(tài)(interrupt status),當線程處于 wait、sleep、join等狀態(tài)時
都在方法內(nèi)部不斷地檢查中斷狀態(tài)的值,當調(diào)用interrupt會拋出InterruptedException異常。

創(chuàng)新互聯(lián)公司2013年開創(chuàng)至今,是專業(yè)互聯(lián)網(wǎng)技術服務公司,擁有項目網(wǎng)站建設、成都網(wǎng)站設計網(wǎng)站策劃,項目實施與項目整合能力。我們以讓每一個夢想脫穎而出為使命,1280元曲江做網(wǎng)站,已為上家服務,為曲江各地企業(yè)和個人服務,聯(lián)系電話:18980820575

interrupt方法
Thread實例方法: 必須由其它線程獲取被調(diào)用線程的實例后,進行調(diào)用。實際上,只是改變了被調(diào)用線程的內(nèi)部中斷狀態(tài);

Thread.interrupted方法
Thread類方法: 必須在當前執(zhí)行線程內(nèi)調(diào)用,該方法返回當前線程的內(nèi)部中斷狀態(tài),然后清除中斷狀態(tài)(置為false)

isInterrupted方法
Thread實例方法:用來檢查指定線程的中斷狀態(tài)。當線程為中斷狀態(tài)時,會返回true;否則返回false。

二、協(xié)調(diào)
wait set / wait方法
每個Java類的實例都有一個wait set,當對象執(zhí)行wait方法時,當前線程就會暫停,并進入該對象的wait set
注: 當前線程若要執(zhí)行obj.wait(),則必須先獲取該對象鎖。當線程進入wait set后,就已經(jīng)釋放了該對象鎖。

notify方法
notify方法相當于從wait set中從挑出一個線程并喚醒。
下圖中線程A在當前實例對象的wait set中等待,此時線程B必須拿到同一實例的對象鎖,才能調(diào)用notify方法喚醒wait set中的任意一個線程。

notifyAll方法
notifyAll方法相當于將wait set中的所有線程都喚醒。

wait、notify、notifyAll這三個方法都是java.lang.Object類的方法(注意,不是Thread類的方法)。
若線程沒有拿到當前對象鎖就直接調(diào)用對象的這些方法,都會拋出java.lang.IllegalMonitorStateException異常。

  • obj.wait()是把當前線程放到obj的wait set;
  • obj.notify()是從obj的wait set里喚醒1個線程;
  • obj.notifyAll()是喚醒所有在obj的wait set里的線程。

三、線程的狀態(tài)轉移

  • 當創(chuàng)建一個Thread子類或實現(xiàn)Runnable接口類的實例時,線程進入【初始】狀態(tài);
  • 調(diào)用實例的start方法后,線程進入【可執(zhí)行】狀態(tài);
  • 系統(tǒng)會在某一時刻自動調(diào)度處于【可執(zhí)行】狀態(tài)的線程,被調(diào)度的線程會調(diào)用run方法,進入【執(zhí)行中】狀態(tài);
  • 線程執(zhí)行完run方法后,進入【結束】狀態(tài);
  • 處于【結束】狀態(tài)的線程,在某一時刻,會被JVM垃圾回收;
  • 處于【執(zhí)行中】狀態(tài)的線程,若調(diào)用了Thread.yield方法,會回到【可執(zhí)行】狀態(tài),等待再次被調(diào)度;
  • 處于【執(zhí)行中】狀態(tài)的線程,若調(diào)用了wait方法,會進入wait set并一直等待,直到被其它線程通過notify、notifyAll、interrupt方法喚醒;
  • 處于【執(zhí)行中】狀態(tài)的線程,若調(diào)用了Thread.sleep方法,會進入【Sleep】狀態(tài),無法繼續(xù)向下執(zhí)行。當sleep時間結束或被interrupt時,會回到【可執(zhí)行狀態(tài)】;
  • 處于【執(zhí)行中】狀態(tài)的線程,若遇到阻塞I/O操作,也會停止等待I/O完成,然后回到【可執(zhí)行狀態(tài)】

四、不可變模式
Immutable(不變的)參與者
Immutable參與者是一個字段值無法更改的類,也沒有任何用來更改字段值的方法。當Immutable參與者的實例建立后,狀態(tài)就完全不再變化。

適用場景:
Immutable模式的優(yōu)點在于,“不需要使用synchronized保護”。而“不需要使用synchronized保護”的大優(yōu)點就是可在不喪失安全性與生命性的前提下,提高程序的執(zhí)行性能。若例由多數(shù)線程所共享實,且訪問非常頻繁,Immutable模式就能發(fā)揮極大的優(yōu)點。(final修飾變量性能高的原因之一)

參考:https://segmentfault.com/blog/ressmix_multithread?page=3

創(chuàng)新互聯(lián)www.cdcxhl.cn,專業(yè)提供香港、美國云服務器,動態(tài)BGP最優(yōu)骨干路由自動選擇,持續(xù)穩(wěn)定高效的網(wǎng)絡助力業(yè)務部署。公司持有工信部辦法的idc、isp許可證, 機房獨有T級流量清洗系統(tǒng)配攻擊溯源,準確進行流量調(diào)度,確保服務器高可用性。佳節(jié)活動現(xiàn)已開啟,新人活動云服務器買多久送多久。

網(wǎng)站欄目:Java進階(7)-并發(fā)(多線程基本概念)-創(chuàng)新互聯(lián)
文章地址:http://bm7419.com/article8/hcgip.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供ChatGPT、網(wǎng)站營銷、品牌網(wǎng)站制作、軟件開發(fā)、移動網(wǎng)站建設、App開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)

小程序開發(fā)