線程和進(jìn)程的定義
線程是進(jìn)程的基本執(zhí)行單元,一個(gè)進(jìn)程的所有任務(wù)都在線程中執(zhí)行
進(jìn)程要想執(zhí)行任務(wù)逞力,必須得有線程锅论,進(jìn)程至少要有一條線程
程序啟動會默認(rèn)開啟一條線程,這條線程被稱為主線程或 UI 線程
進(jìn)程是指在系統(tǒng)中正在運(yùn)行的一個(gè)應(yīng)用程序
每個(gè)進(jìn)程之間是獨(dú)立的令宿,每個(gè)進(jìn)程均運(yùn)行在其專用的且受保護(hù)的內(nèi)存空間內(nèi)
通過“活動監(jiān)視器”可以查看 Mac 系統(tǒng)中所開啟的進(jìn)程
進(jìn)程與線程的關(guān)系
地址空間:同一進(jìn)程的線程共享本進(jìn)程的地址空間叼耙,而進(jìn)程之間則是獨(dú)立的地址空間。 資源擁有:同一進(jìn)程內(nèi)的線程共享本進(jìn)程的資源如內(nèi)存粒没、I/O筛婉、cpu等,但是進(jìn)程之間的 資源是獨(dú)立的癞松。
1: 一個(gè)進(jìn)程崩潰后爽撒,在保護(hù)模式下不會對其他進(jìn)程產(chǎn)生影響入蛆,但是一個(gè)線程崩潰整個(gè)進(jìn) 程都死掉。所以多進(jìn)程要比多線程健壯硕勿。 2: 進(jìn)程切換時(shí)哨毁,消耗的資源大,效率高源武。所以涉及到頻繁的切換時(shí)挑庶,使用線程要好于進(jìn) 程。同樣如果要求同時(shí)進(jìn)行并且又要共享某些變量的并發(fā)操作软能,只能用線程不能用進(jìn)程 3: 執(zhí)行過程:每個(gè)獨(dú)立的進(jìn)程有一個(gè)程序運(yùn)行的入口迎捺、順序執(zhí)行序列和程序入口。但是 線程不能獨(dú)立執(zhí)行查排,必須依存在應(yīng)用程序中凳枝,由應(yīng)用程序提供多個(gè)線程執(zhí)行控制。
4: 線程是處理器調(diào)度的基本單位跋核,但是進(jìn)程不是岖瑰。 5: 線程沒有地址空間,線程包含在進(jìn)程地址空間中
優(yōu)點(diǎn)
能適當(dāng)提高程序的執(zhí)行效率
能適當(dāng)提高資源的利用率(CPU,內(nèi)存)
線程上的任務(wù)執(zhí)行完成后砂代,線程會自動銷毀
缺點(diǎn)
開啟線程需要占用一定的內(nèi)存空間(默認(rèn)情況下蹋订,每一個(gè)線程都占 512 KB)
如果開啟大量的線程,會占用大量的內(nèi)存空間刻伊,降低程序的性能
線程越多露戒,CPU 在調(diào)用線程上的開銷就越大
程序設(shè)計(jì)更加復(fù)雜,比如線程間的通信捶箱、多線程的數(shù)據(jù)共享
時(shí)間片的概念:CPU在多個(gè)任務(wù)直接進(jìn)行快速的切換智什,這個(gè)時(shí)間間隔就是時(shí)間片
(單核CPU)同一時(shí)間,CPU 只能處理 1 個(gè)線程
換言之丁屎,同一時(shí)間只有 1 個(gè)線程在執(zhí)行
多線程同時(shí)執(zhí)行:
是 CPU 快速的在多個(gè)線程之間的切換
CPU 調(diào)度線程的時(shí)間足夠快荠锭,就造成了多線程的“同時(shí)”執(zhí)行的效果
如果線程數(shù)非常多
CPU 會在 N 個(gè)線程之間切換,消耗大量的 CPU 資源
每個(gè)線程被調(diào)度的次數(shù)會降低晨川,線程的執(zhí)行效率降低
飽和策略
? AbortPolicy 直接拋出RejectedExecutionExeception異常來阻止系統(tǒng)正常運(yùn)行
? CallerRunsPolicy 將任務(wù)回退到調(diào)用者
? DisOldestPolicy 丟掉等待最久的任務(wù)
? DisCardPolicy 直接丟棄任務(wù)
這四種拒絕策略均實(shí)現(xiàn)的RejectedExecutionHandler接口
atomic與nonatomic 的區(qū)別
nonatomic 非原子屬性 atomic 原子屬性(線程安全)证九,針對多線程設(shè)計(jì)的,默認(rèn)值
保證同一時(shí)間只有一個(gè)線程能夠?qū)懭?但是同一個(gè)時(shí)間多個(gè)線程都可以取值) atomic 本身就有一把鎖(自旋鎖) 單寫多讀:單個(gè)線程寫入共虑,多個(gè)線程可以讀取
atomic:線程安全愧怜,需要消耗大量的資源
nonatomic:非線程安全,適合內(nèi)存小的移動設(shè)備
iOS 開發(fā)的建議
所有屬性都聲明為 nonatomic 盡量避免多線程搶奪同一塊資源 盡量將加鎖看蚜、資源搶奪的業(yè)務(wù)邏輯交給服務(wù)器端處理叫搁,減小移動客戶端的壓力
線程和Runloop的關(guān)系
1:runloop與線程是一一對應(yīng)的,一個(gè)runloop對應(yīng)一個(gè)核心的線程,為什么說是核心 的渴逻,是因?yàn)閞unloop是可以嵌套的疾党,但是核心的只能有一個(gè),他們的關(guān)系保存在一個(gè)全局 的字典里惨奕。
2:runloop是來管理線程的雪位,當(dāng)線程的runloop被開啟后,線程會在執(zhí)行完任務(wù)后進(jìn)入休 眠狀態(tài)梨撞,有了任務(wù)就會被喚醒去執(zhí)行任務(wù)雹洗。
3:runloop在第一次獲取時(shí)被創(chuàng)建,在線程結(jié)束時(shí)被銷毀卧波。
4:對于主線程來說时肿,runloop在程序一啟動就默認(rèn)創(chuàng)建好了。
5:對于子線程來說港粱,runloop是懶加載的螃成,只有當(dāng)我們使用的時(shí)候才會創(chuàng)建,所以在子線 程用定時(shí)器要注意:確保子線程的runloop被創(chuàng)建查坪,不然定時(shí)器不會回調(diào)寸宏。