它與非實(shí)時(shí)調(diào)度有什么區(qū)別?
答:實(shí)時(shí)調(diào)度是為了完成實(shí)時(shí)處理任務(wù)而分配計(jì)算機(jī)處理器的調(diào)度方法。
實(shí)時(shí)處理任務(wù)要求計(jì)算機(jī)在用戶(hù)允許的時(shí)限范圍內(nèi)給出計(jì)算機(jī)響應(yīng)信號(hào)。實(shí)時(shí)處理任務(wù)可分為 硬實(shí)時(shí)任務(wù)(hardrea[—timetask)和軟實(shí)時(shí)任務(wù)(softreal—timetask)。硬實(shí)時(shí)任務(wù)要求計(jì)算 機(jī)系統(tǒng)必須在用戶(hù)給定的時(shí)限內(nèi)處理完畢,軟實(shí)時(shí)任務(wù)允許計(jì)算機(jī)系統(tǒng)在用戶(hù)給定的時(shí)限左右 處理完畢。 針對(duì)硬實(shí)時(shí)任務(wù)和軟實(shí)時(shí)任務(wù),計(jì)算機(jī)系統(tǒng)可以有不同的實(shí)時(shí)調(diào)度算法。這些算法采用基于優(yōu) 先級(jí)的搶先式調(diào)度策略,具體地說(shuō),大致有如下幾類(lèi): (1)靜態(tài)表驅(qū)動(dòng)模式。該模式用于周期性實(shí)時(shí)調(diào)度,它在任務(wù)到達(dá)之前對(duì)各任務(wù)搶占處理機(jī)的 時(shí)間進(jìn)行分析,并根據(jù)分析結(jié)果進(jìn)行調(diào)度。 (2)靜態(tài)優(yōu)先級(jí)驅(qū)動(dòng)的搶先式調(diào)度模式。該模式也進(jìn)行靜態(tài)分析。分析結(jié)果不是用于調(diào)度,只是 用于給各任務(wù)指定優(yōu)先級(jí)。系統(tǒng)根據(jù)各任務(wù)的優(yōu)先級(jí)進(jìn)行搶先式調(diào)度。 (3)基于計(jì)劃的動(dòng)態(tài)模式。該模式在新任務(wù)到達(dá)后,將以前調(diào)度過(guò)的任務(wù)與新到達(dá)的任務(wù)一起統(tǒng) 一計(jì)劃,分配CPU時(shí)間。 (4)動(dòng)態(tài)盡力而為模式。該模式不進(jìn)行任何關(guān)于資源利用率的分析,只檢查各任務(wù)的時(shí)限是否能 得到滿(mǎn)足。 代表性的實(shí)時(shí)調(diào)度算法有兩種。即時(shí)限式調(diào)度法(deadlinescheduling)和頻率單調(diào)調(diào)度法 (ratemonotonicscheduling)。 實(shí)時(shí)調(diào)度與非實(shí)時(shí)調(diào)度的主要區(qū)別是: (1)實(shí)時(shí)調(diào)度所調(diào)度的任務(wù)有完成時(shí)限,而非實(shí)時(shí)調(diào)度沒(méi)有。從而,實(shí)時(shí)調(diào)度算法的正確與否不 僅與算法的邏輯有關(guān),也與調(diào)度算法調(diào)度的時(shí)限有關(guān)。 (2)實(shí)時(shí)調(diào)度要求較快的進(jìn)程或線程切換時(shí)間,而非實(shí)時(shí)調(diào)度的進(jìn)程或線程的切換時(shí)間較長(zhǎng)。 (3)非實(shí)時(shí)調(diào)度強(qiáng)調(diào)資源利用率(批處理系統(tǒng))或用戶(hù)共享處理機(jī)(分時(shí)系統(tǒng)),實(shí)時(shí)調(diào)度則主要強(qiáng) 調(diào)在規(guī)定時(shí)限范圍內(nèi)完成對(duì)相應(yīng)設(shè)備的控制。 (4)實(shí)時(shí)調(diào)度為搶先式調(diào)度,而非實(shí)時(shí)調(diào)度則很少采用搶先式調(diào)度