基本概念
1. 程序、進(jìn)程、線程
- 程序(program)是為完成特定任務(wù)、用某種語言編寫的一組指令的集合。即指一段靜態(tài)的代碼,靜態(tài)對象。
- 進(jìn)程(process)是程序的一次執(zhí)行過程,或是正在運(yùn)行的一個(gè)程序。是一個(gè)動(dòng)態(tài)的過程:有它自身的產(chǎn)生、存在和消亡的過程?!芷?
- 如:運(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),線程切換的開銷小
-
一個(gè)進(jìn)程中的多個(gè)線程共享相同的內(nèi)存單元/內(nèi)存地址空間
它們從同一堆中分配對象,可以訪問相同的變量和對象。這就使得線程間通信更簡便、高效。但多個(gè)線程操作共享的系統(tǒng)資源可能就會(huì)帶來安全的隱患。
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)。對圖形化界面更有意義,可增強(qiáng)用戶體驗(yàn)。
- 提高計(jì)算機(jī)系統(tǒng)CPU的利用率
- 改善程序結(jié)構(gòu)。將既長又復(fù)雜的進(jìn)程分為多個(gè)線程,獨(dú)立運(yùn)行,利于理解和修改。
4. 何時(shí)需要多線程
- 程序需要同時(shí)執(zhí)行兩個(gè)或多個(gè)任務(wù)。
- 程序需要實(shí)現(xiàn)一些需要等待的任務(wù)時(shí),如用戶輸入、文件讀寫操作、網(wǎng)絡(luò)操作、搜索等。
- 需要一些后臺(tái)運(yùn)行的程序時(shí)。
