基本概念
1. 程序、進(jìn)程叮贩、線程
- 程序(program)是為完成特定任務(wù)击狮、用某種語(yǔ)言編寫(xiě)的一組指令的集合佛析。即指一段靜態(tài)的代碼,靜態(tài)對(duì)象彪蓬。
- 進(jìn)程(process)是程序的一次執(zhí)行過(guò)程寸莫,或是正在運(yùn)行的一個(gè)程序。是一個(gè)動(dòng)態(tài)的過(guò)程:有它自身的產(chǎn)生档冬、存在和消亡的過(guò)程膘茎。——生命周期
- 如:運(yùn)行中的QQ酷誓,運(yùn)行中的MP3播放器
- 程序是靜態(tài)的披坏,進(jìn)程是動(dòng)態(tài)的
- 進(jìn)程作為資源分配的單位,系統(tǒng)在運(yùn)行時(shí)會(huì)為每個(gè)進(jìn)程分配不同的內(nèi)存區(qū)域
- 線程(thread)盐数,進(jìn)程可進(jìn)一步細(xì)化為線程棒拂,是一個(gè)程序內(nèi)部的一條執(zhí)行路徑。
- 若一個(gè)進(jìn)程同一時(shí)間并行執(zhí)行多個(gè)線程玫氢,就是支持多線程的
- 線程作為調(diào)度和執(zhí)行的單位帚屉,每個(gè)線程擁有獨(dú)立的運(yùn)行棧和程序計(jì)數(shù)器(pc),線程切換的開(kāi)銷小
-
一個(gè)進(jìn)程中的多個(gè)線程共享相同的內(nèi)存單元/內(nèi)存地址空間
它們從同一堆中分配對(duì)象漾峡,可以訪問(wèn)相同的變量和對(duì)象攻旦。這就使得線程間通信更簡(jiǎn)便、高效生逸。但多個(gè)線程操作共享的系統(tǒng)資源可能就會(huì)帶來(lái)安全的隱患牢屋。
2. 并行與并發(fā)
- 并行:多個(gè)CPU同時(shí)執(zhí)行多個(gè)任務(wù)。
- 并發(fā):一個(gè)CPU(采用時(shí)間片)同時(shí)執(zhí)行多個(gè)任務(wù)牺陶。
3. 多線程程序的優(yōu)點(diǎn):
- 提高應(yīng)用程序的響應(yīng)伟阔。對(duì)圖形化界面更有意義,可增強(qiáng)用戶體驗(yàn)掰伸。
- 提高計(jì)算機(jī)系統(tǒng)CPU的利用率
- 改善程序結(jié)構(gòu)。將既長(zhǎng)又復(fù)雜的進(jìn)程分為多個(gè)線程怀估,獨(dú)立運(yùn)行狮鸭,利于理解和修改。
4. 何時(shí)需要多線程
- 程序需要同時(shí)執(zhí)行兩個(gè)或多個(gè)任務(wù)多搀。
- 程序需要實(shí)現(xiàn)一些需要等待的任務(wù)時(shí)歧蕉,如用戶輸入、文件讀寫(xiě)操作康铭、網(wǎng)絡(luò)操作惯退、搜索等。
- 需要一些后臺(tái)運(yùn)行的程序時(shí)从藤。