新聞中心

EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 單片機(jī)實(shí)時(shí)操作系統(tǒng)中進(jìn)程與鄉(xiāng)程

單片機(jī)實(shí)時(shí)操作系統(tǒng)中進(jìn)程與鄉(xiāng)程

作者: 時(shí)間:2016-11-24 來(lái)源:網(wǎng)絡(luò) 收藏
注意:在單片機(jī)中一般沒(méi)有MMU,最多cortex-3也只能實(shí)現(xiàn)MPU功能,所以它不能轉(zhuǎn)換虛擬地址空間。所以只有一個(gè)進(jìn)程。因此基于單片機(jī)實(shí)現(xiàn)的多任務(wù)都是線程。

本文引用地址:http://butianyuan.cn/article/201611/321059.htm

在32位的Windows系統(tǒng)中,術(shù)語(yǔ)多任務(wù)是指系統(tǒng)可以同時(shí)運(yùn)行多個(gè)進(jìn)程,而每個(gè)進(jìn)程也可以同時(shí)執(zhí)行多個(gè)線程。

----------------------------------------------------------------------------------------------------------------------

進(jìn)程能開(kāi)多少個(gè)? 
進(jìn)程表不可以無(wú)限開(kāi)。每個(gè)進(jìn)程在系統(tǒng)內(nèi)核的進(jìn)程表中都有記錄,以便于系統(tǒng)的調(diào)度,在進(jìn)程表中應(yīng)該會(huì)給每個(gè)進(jìn)程一個(gè)固定長(zhǎng)度的編號(hào),比如說(shuō)8位或16位的二進(jìn)制號(hào)碼,編號(hào)的長(zhǎng)度決定了系統(tǒng)最多可以調(diào)度的進(jìn)程數(shù)。一般XP開(kāi)200個(gè)進(jìn)程沒(méi)問(wèn)題的,只要配置高一點(diǎn)。


1、那么一個(gè)進(jìn)程能開(kāi)多少線程?

默認(rèn)情況下,一個(gè)線程的棧要預(yù)留1M的內(nèi)存空間,而一個(gè)進(jìn)程中可用的內(nèi)存空間只有2G,所以理論上一個(gè)進(jìn)程中最多可以開(kāi)2048個(gè)線程,但是內(nèi)存當(dāng)然不可能完全拿來(lái)作線程的棧,所以實(shí)際數(shù)目要比這個(gè)值要小。

能開(kāi)多少進(jìn)程是根據(jù)內(nèi)存限制的。

2.如何突破2000個(gè)限制?
你也可以通過(guò)連接時(shí)修改默認(rèn)棧大小,將其改的比較小,這樣就可以多開(kāi)一些線程。如將默認(rèn)棧的大小改成512K,這樣理論上最多就可以開(kāi)4096個(gè)線程。
即使物理內(nèi)存再大,一個(gè)進(jìn)程中可以起的線程總要受到2GB這個(gè)內(nèi)存空間的限制。比方說(shuō)你的機(jī)器裝了64GB物理內(nèi)存,但每個(gè)進(jìn)程的內(nèi)存空間還是4GB,其中用戶態(tài)可用的還是2GB。

如果是同一臺(tái)機(jī)器內(nèi)的話,能起多少線程也是受內(nèi)存限制的。每個(gè)線程對(duì)象都要站用非頁(yè)面內(nèi)存,而非頁(yè)面內(nèi)存也是有限的,當(dāng)非頁(yè)面內(nèi)存被耗盡時(shí),也就無(wú)法創(chuàng)建線程了。

如果物理內(nèi)存非常大,同一臺(tái)機(jī)器內(nèi)可以跑的線程數(shù)目的限制值會(huì)越來(lái)越大。

可以通過(guò)修改CreateThread參數(shù)來(lái)縮小線程棧StackSize,

----------------------------------------------------------------------------------------------------------------------
進(jìn)程就是應(yīng)用程序的運(yùn)行實(shí)例。每個(gè)進(jìn)程都有自己私有的虛擬地址空間。每個(gè)進(jìn)程都有一個(gè)主線程,但可以建立另外的線程。進(jìn)程中的線程是并行執(zhí)行的,每個(gè)線程占用CPU的時(shí)間由系統(tǒng)來(lái)劃分。


可以把線程看成是操作系統(tǒng)分配CPU時(shí)間的基本實(shí)體。系統(tǒng)不停地在各個(gè)線程之間切換,它對(duì)線程的中斷是匯編語(yǔ)言級(jí)的。系統(tǒng)為每一個(gè)線程分配一個(gè)CPU時(shí)間片,某個(gè)線程只有在分配的時(shí)間片內(nèi)才有對(duì)CPU的控制權(quán)。實(shí)際上,在PC機(jī)中,同一時(shí)間只有一個(gè)線程在運(yùn)行。由于系統(tǒng)為每個(gè)線程劃分的時(shí)間片很?。?0毫秒左右),所以看上去好象是多個(gè)線程在同時(shí)運(yùn)行。

進(jìn)程中的所有線程共享進(jìn)程的虛擬地址空間,這意味著所有線程都可以訪問(wèn)進(jìn)程的全局變量和資源。這一方面為編程帶來(lái)了方便,但另一方面也容易造成沖突。

雖然在進(jìn)程中進(jìn)行費(fèi)時(shí)的工作不會(huì)導(dǎo)致系統(tǒng)的掛起,但這會(huì)導(dǎo)致進(jìn)程本身的掛起。所以,如果進(jìn)程既要進(jìn)行長(zhǎng)期的工作,又要響應(yīng)用戶的輸入,那么它可以啟動(dòng)一個(gè)線程來(lái)專門(mén)負(fù)責(zé)費(fèi)時(shí)的工作,而主線程仍然可以與用戶進(jìn)行交互。

簡(jiǎn)單的說(shuō),你每啟動(dòng)一個(gè)程序,就啟動(dòng)了一個(gè)進(jìn)程。在Windows 3.x下,進(jìn)程是最小運(yùn)行單位。在Windows 95/NT下,每個(gè)進(jìn)程還可以啟動(dòng)幾個(gè)線程,比如每下載一個(gè)文件可以單獨(dú)開(kāi)一個(gè)線程。在Windows 95/NT下,線程是最小單位。WINDOWS的多任務(wù)特性使得線程之間獨(dú)立運(yùn)行,但是它們彼此共享虛擬空間,也就是共用變量,線程有可能會(huì)同時(shí)操作一片內(nèi)存。

所謂進(jìn)程,本身不能執(zhí)行,它只是一個(gè)資源的集合體,擁有地址空間,模塊,內(nèi)存,...
線程是真正的執(zhí)行單元,一個(gè)進(jìn)程如果沒(méi)有線程,那么就沒(méi)有存在的意義,因?yàn)椴豢赡軋?zhí)行



評(píng)論


技術(shù)專區(qū)

關(guān)閉