前言:想要寫出一篇令人眼前一亮的文章嗎?我們特意為您整理了5篇程序設(shè)計論文范文,相信會為您的寫作帶來幫助,發(fā)現(xiàn)更多的寫作思路和靈感。
一、前言
Windows提供強(qiáng)大的功能以及友好的圖形用戶界面(GUI),使得它不僅廣泛的用作管理事務(wù)型工作的支持平臺,也被工業(yè)領(lǐng)域的工程人員所關(guān)注。但Windows3.1并非基于優(yōu)先級來調(diào)度任務(wù),無法立即響應(yīng)外部事件中斷,也就不能滿足工業(yè)應(yīng)用環(huán)境中實時事件處理和實時控制應(yīng)用的要求。因此,如何在Windows環(huán)境中處理外部實時事件一直是技術(shù)人員尤其是實時領(lǐng)域工程人員所關(guān)注的問題。目前已有的方法大都采用內(nèi)掛實時多任務(wù)內(nèi)核的方式,如Windows下的實時控制軟件包FLX等,而iRMX實時操作系統(tǒng)則把Windows3.1當(dāng)作它的一個任務(wù)來運(yùn)行。對于大型的工程項目,開發(fā)人員可采用購買實時軟件然后集成方式。
對中小項目,從投資上考慮就不很經(jīng)濟(jì)。如何尋找一種簡明的方法來處理外部實時事件依然顯得很必要。
本文首先闡述Windwos的消息機(jī)制及中斷機(jī)制,然后結(jié)合DPMI接口,給出一種保護(hù)模式下中斷程序的設(shè)計方法,以處理外部實時事件。經(jīng)實際運(yùn)行結(jié)果表明,該方法具有簡潔、實用、可靠的特點,并同樣可運(yùn)行于Win95。
二、Windows的消息機(jī)制
Windows是一消息驅(qū)動式系統(tǒng),見圖1。Windows消息提供了應(yīng)用程序與應(yīng)用程序之間、應(yīng)用程序與Windows系統(tǒng)之間進(jìn)行通訊的手段。應(yīng)用程序要實現(xiàn)的功能由消息來觸發(fā),并靠對消息的響應(yīng)和處理來完成。
Windows系統(tǒng)中有兩種消息隊列,一種是系統(tǒng)消息隊列,另一種是應(yīng)用程序消息隊列。計算機(jī)的所有輸入設(shè)備由Windows監(jiān)控,當(dāng)一個事件發(fā)生時,Windows先將輸入的消息放入系統(tǒng)消息隊列中,然后再將輸入的消息拷貝到相應(yīng)的應(yīng)用程序隊列中。應(yīng)用程序中的消息循環(huán)從它的消息隊列中檢索每一個消息并發(fā)送給相應(yīng)的窗口函數(shù)中。一個事件的發(fā)生,到達(dá)處理它的窗口函數(shù)必需經(jīng)歷上述過程。值得注意的是消息的非搶先性,即不論事件的急與緩,總是按到達(dá)的先后排隊(一些系統(tǒng)消息除外),這就使得一些外部實時事件可能得不到及時的處理。
圖1
三、Windows的保護(hù)模式及中斷機(jī)制
1.Windows的保護(hù)模式
保護(hù)模式指的是線性地址由一個選擇符間接生成的,該選擇符指向描述表中的某一項;而實模式中則通過一個段/偏移量對來直接尋址。80386(486)CPU提供的保護(hù)模式能力包括一個64K的虛擬地址空間和一個4G的段尺寸。Windows3.1實現(xiàn)時有所差別,它支持標(biāo)準(zhǔn)模式和增強(qiáng)模式。標(biāo)準(zhǔn)模式針對286機(jī)器,不屬本文探討范圍。增強(qiáng)模式是對386以上CPU而言,Windows正是使用保護(hù)模式來打破1M的屏障并且執(zhí)行簡單的內(nèi)存保護(hù)。它使用選擇器、描述器和描述器表控制訪問指定內(nèi)存的位置和段。描述器表包括全局描述器表、局部描述器表、中斷描述器表。保護(hù)模式與實模式有許多不同。其中顯著的差異是訪問內(nèi)存的機(jī)制不同。
2.中斷機(jī)制
(1)實模式中斷
為了便于理解,我們先回顧實模式中斷。
在實模式下,中斷向量表IVT起到相當(dāng)重要的作用。無論來自外部硬件的中斷或是內(nèi)部的軟中斷INTn,在CPU中都產(chǎn)生同樣的響應(yīng)。
①CPU將當(dāng)前的指令指針寄存器(IP)、代碼段寄存器(CS)、標(biāo)志寄存器壓入堆棧。
②然后CPU使用n值作為指向中斷向量表IVT的索引,在IVT中找出服務(wù)例程的遠(yuǎn)地址。
③CPU將此遠(yuǎn)地址裝入CS:IP寄存器中,并開始執(zhí)行服務(wù)例程。
④中斷例程總以IRET指令結(jié)束。此指令使存在堆棧中的三個值彈出并填入CS、IP和標(biāo)志寄存器,CPU繼續(xù)執(zhí)行原來的指令。
(2)保護(hù)模式中斷
保護(hù)模式中斷過程與實模式中斷過程類似,但它不再使用中斷向量表IVT,而使用中斷描述符表(IDT)。值得一提的是,Windows運(yùn)行時IVT還存在,應(yīng)用程序并不使用它,Windows仍然使用,但含義已不同。
①IVT結(jié)構(gòu):IVT在RAM的0000∶0000之上,占據(jù)開始的1024字節(jié)。
它仍然由BIOS啟動例程設(shè)置,由DOS填充到RAM中。
②IDT中斷描述符表:保護(hù)模式下,Windows操作系統(tǒng)為實現(xiàn)中斷機(jī)制而建立的一個特殊表,即中斷描述符表IDT。該表被用來保存中斷服務(wù)例程的線性地址,它們是真正的24位或32位地址,沒有段:偏移值結(jié)構(gòu)。中斷描述器表最多可含有256個例程說明,詳細(xì)說明請見【3】。I
DT結(jié)構(gòu)見圖2。
圖2
③當(dāng)中斷或異常發(fā)生時,處理過程與實模式類同。當(dāng)前的CS∶IP值和標(biāo)志寄存器值被存儲。保存的內(nèi)容還包括CPU其他內(nèi)部寄存器的值,以及目前正在被執(zhí)行的任務(wù)的有關(guān)信息(若必須發(fā)生任務(wù)切換的話)。CPU設(shè)法獲取中斷向量后,以它為索引值,查找IDT中的服務(wù)例程遠(yuǎn)地址,接著將控制轉(zhuǎn)移到該處的服務(wù)例程。這是與實模式轉(zhuǎn)移到IVT的不同所在。保護(hù)模式使用IDTR寄存器分配和定位內(nèi)存中的IDT中斷描述符表。IDT在內(nèi)存中是可移動的,與IVT固定在內(nèi)存中剛好相反。IDT中斷描述符表在Windows中起決定性的作用。理解了Windows下保護(hù)模
式的中斷機(jī)制。有助于我們理解中斷服務(wù)程序的設(shè)計,它的關(guān)鍵就在于如何將服務(wù)例程的地址放入IDT中斷描述符表中。當(dāng)中斷發(fā)生時,如何將斷點地址及CPU各寄存器值保護(hù)起來;中斷結(jié)束時,如何將保護(hù)的值恢復(fù)。Windows系統(tǒng)本身并不提供實現(xiàn)上述功能的API,而DOS保護(hù)模式接口DPMI正具備了上述的功能。
下面我們首先介紹DPMI接口,然后基于它實現(xiàn)Windows下中斷服務(wù)程序的設(shè)計。
四、DOS保護(hù)模式接口DPMI
Windows除了標(biāo)準(zhǔn)服務(wù)外,還支持一組特殊的DOS服務(wù),稱為DOS保護(hù)模式接口DPMI,由一些INT2FH和INT31H服務(wù)組成。它使應(yīng)用程序能夠訪問PC系列計算機(jī)的擴(kuò)充內(nèi)存,同時維護(hù)系統(tǒng)的保護(hù)功能。DPMI通過軟件中斷31h來定義了一個新的接口,使得保護(hù)模式的應(yīng)用程序能夠用它作分配內(nèi)存,修改描述符以及調(diào)用實模式軟件等工作。
Windows為應(yīng)用程序提供DPMI服務(wù)。即Windows是DPMI的宿主(host),應(yīng)用程序是DPMI的客戶(client),可通過INT-31H調(diào)用得到DPMI服務(wù)。INT-31H本身提供多功能。其中它的中斷管理服務(wù)允許保護(hù)模式用于攔截實模式中斷,并且掛住處理器異常。有些服務(wù)能夠和DPMI宿主合作,以維護(hù)應(yīng)用程序的虛擬中斷標(biāo)志。
可以用INT31H來掛住保護(hù)模式中斷向量,以中斷方式處理外部實時事件。利用INT31H,功能0205H:設(shè)置保護(hù)模式中斷向量,將特定中斷的保護(hù)模式處理程序的地址置入中斷向量里。調(diào)用方式:AX=0205H,BL=中斷號,CX∶(E)DX=中斷處理程序選擇符:偏移值。返回:執(zhí)行成功CF=清零,執(zhí)行失敗CF=置位。
掛住/解掛中斷向量的時機(jī)很重要。主窗口第一次被創(chuàng)建時會傳送它WM-CREATE消息,這時是掛住中斷向量的最好時機(jī)。退出時需解掛向量,否則Windows可能崩潰。主窗口接收到WM-DE-STROY之后進(jìn)行解掛工作,是最適合的。解掛向量可先用INT35H,0204H功能將老的中斷向量保存,退出時用INT35H,0205H恢復(fù)。
五、編程實現(xiàn)
有了DPMI的支持,我們就可以很方便地處理數(shù)據(jù)采集、串行通信等工業(yè)過程中的實時事件。下面以Windows3.1平臺下中斷方式實現(xiàn)的串行通信為例,說明中斷程序的編制和實現(xiàn)。為便于參考,給出了詳細(xì)的代碼。開發(fā)平臺BC3.1/BC4.5,其本身支持0.9版的DPMI,無需運(yùn)行其它支持DPMI的軟件。編程語言C,可與C++混合編譯。
初始化COM1,9600波特率,每字符8bits,1個停止位,中斷接收,查詢發(fā)送。
//windowsasycommunication
//byLiXiuming
//lastmodifiedonJune25,1996
#include〈windows.h〉
#include〈dos.h〉
voidinterruptfarDataReceive();
voidinterruptfar(*old-vector)();
unsignedchardatacom-r[1024],datacom-s[1024];
intinflag=0;
unsignedints8259;
intInitCom1()
{//串口1初使化
s8259=inportb(0x21);//讀入8259當(dāng)前狀態(tài)并保存
outportb(0x21,s8259&0xe8);//初始化8259,允許0x0c號中斷
outportb(0x3fb,0x83);
outportb(0x3f8,0x0c);
outportb(0x3f9,0x00);
outportb(0x3fb,0x03);
outportb(0x3fc,0x08);//允許中斷信號送到8259A,以便能中斷
outportb(0x3f9,0x01);//0x01,中斷允許
return1;
}
voidinterruptfarDataReceive()
{//中斷接收子程序
staticinti=0;//靜態(tài)局部變量
charrechar=0;//每中斷一次,i自動加1
rechar=inportb(0x3f8);//從數(shù)據(jù)口讀出發(fā)送過來的數(shù)據(jù)
if(inflag==0)
{
if(rechar!=s&&i==0)//幀起始
{
i=0;
gotoll;
}
datacom-r[i++]=rechar;//存入datacom-r[](通信緩沖區(qū))
if(rechar==e)//幀結(jié)束
{
inflag=1;
i=0;
}
}
ll:outportb(0x20,0x20);//回送中斷結(jié)束標(biāo)志
}
//調(diào)用DPMI
//保存舊的0CH號保護(hù)模式中斷向量
//設(shè)置新的保護(hù)模式中斷服務(wù)例程
voidInitCom(void)
{
asm{
cli
movax,204h
movbl,0ch
int31h
sti
}
old-vector=MK-FP(-CX,-DX);//保存
asm{cli//設(shè)置新的0x0c中斷服務(wù)例程
movax,205h
movbl,0ch
movcx,segdatareceive
movdx,offsetdatareceive
int31h
sti
}
InitCom1();
}
//恢復(fù)8259狀態(tài)
//恢復(fù)0CH保護(hù)模式向量
voidRestoreComm(void)
{
outportb(0x21,s8259);
asm{
cli
movax,205h
movbl,0ch
movcx,segold-vector
movdx,offsetold-vector
int31h
sti
}
}
在窗口第一次被創(chuàng)建時會傳送它WM-CREATE消息,這時調(diào)用InitCom()即可。在主窗口關(guān)閉時,即主窗口中收到WM-DESTROY消息時,調(diào)用RestoreComm()恢復(fù)原來的狀態(tài)。
這樣在對串口初始化,設(shè)置中斷服務(wù)例程后,通信事件發(fā)生時,會立即跳入中斷子程序中執(zhí)行,越過系統(tǒng)的消息隊列,達(dá)到實時處理通信事件的目的。而數(shù)據(jù)處理模塊可通過全局標(biāo)志flag訪問全局的數(shù)據(jù)通信緩沖區(qū)獲取實時數(shù)據(jù)。這種實現(xiàn)方式與基于消息機(jī)制的Windows通信API實現(xiàn)相比具有實時性強(qiáng)的特點,因為它超過Windows系統(tǒng)的兩極消息機(jī)制。
上述程序已在實際系統(tǒng)中得到應(yīng)用。在Windows3.1支持下,同時運(yùn)行三個Windows任務(wù):服務(wù)器SERVER(內(nèi)有實時串行通信,多個網(wǎng)絡(luò)數(shù)據(jù)子服務(wù)),客戶CLIENT,FOXPRO數(shù)據(jù)庫系統(tǒng)。整個系統(tǒng)運(yùn)行良好。切換到WIN95平臺下(支持0.9版DPMI),系統(tǒng)也運(yùn)行良好。
參考文獻(xiàn)
1張豫夫、曹建文譯.【澳】BarryKauler著.Windows匯編語言及系統(tǒng)程序設(shè)計.北京大學(xué)出版社,1995
案例需要選取復(fù)雜程度適中,學(xué)生比較感興趣的實例,使課堂變得生動活潑。每位同學(xué)設(shè)計自己的實施方案,鼓勵大家去思考、去創(chuàng)造,經(jīng)過老師的講解,可以完成整個案例的實現(xiàn)。學(xué)生之間可以通過討論,經(jīng)驗交流,互相取長補(bǔ)短,完善自己的案例制作。當(dāng)學(xué)生完成作品時,教師應(yīng)當(dāng)對此次案例的實施進(jìn)行總結(jié),并且在此基礎(chǔ)上,將問題延伸,對其進(jìn)行完善或改進(jìn),根據(jù)課時情況,鼓勵學(xué)生設(shè)計并實現(xiàn)。
2與自身專業(yè)相結(jié)合
為了提高VisualBasic程序設(shè)計的實用性,增強(qiáng)學(xué)生學(xué)以致用的能力,需要將該門課程與學(xué)生所學(xué)專業(yè)有機(jī)的結(jié)合在一起,這樣能夠使學(xué)生的學(xué)習(xí)興趣更加濃厚,提高學(xué)習(xí)熱情。以交通運(yùn)輸專業(yè)為例,課程開展至圖形圖像的使用時,可以選取紅綠燈變換例題作為學(xué)生的操作案例,如圖2所示。在這個案例中,與交通專業(yè)的專業(yè)知識也許還有一定的差距,但這樣一個簡單的實例足以吸引學(xué)生的注意力,控件要求也比較簡單,代碼結(jié)構(gòu)并不復(fù)雜,但是需要提醒學(xué)生注意的是需要對于Image3控件需要添加具有3個元素的控件數(shù)組,來存儲紅、黃、綠三種顏色。類似的案例教師可以通過網(wǎng)絡(luò)搜索或圖書資料等多種方法搜集,難度不能太大,如果太復(fù)雜,反而會影響學(xué)生學(xué)習(xí)的積極性,以上就是對于非專業(yè)學(xué)生,將案例教學(xué)法應(yīng)用于理論教學(xué)中的一些建議。
3程序?qū)嵺`教學(xué)改革
程序設(shè)計課程具有很強(qiáng)的實踐性,在培養(yǎng)學(xué)生學(xué)會自己分析問題、使用計算機(jī)解決問題能力的同時提倡學(xué)生創(chuàng)新意識和創(chuàng)新能力的培養(yǎng),主要采用的教學(xué)模式有項目教學(xué)法、案例分析法、任務(wù)驅(qū)動法等。
1.1《VB程序設(shè)計》課程中項目的設(shè)計
1.1.1章節(jié)項目
在整個教學(xué)過程當(dāng)中,采用了“大項目、小案例、任務(wù)驅(qū)動不斷”的教學(xué)模式,設(shè)計并選取與生活相聯(lián)系的合理的能夠調(diào)動學(xué)生學(xué)習(xí)積極性的項目。針對課程教學(xué)的最終目的,設(shè)計了一個比較完整的圖書館管理系統(tǒng)綜合項目,但是這門課程知識點較多,要想完成這個綜合項目,學(xué)生首先必須熟悉VB開發(fā)環(huán)境、掌握VB程序設(shè)計的基本概念和基礎(chǔ)知識、各章節(jié)的知識點內(nèi)容。為了配合整個課程最后綜合項目的完成,在具體的教學(xué)中按照教學(xué)內(nèi)容由易到難,針對教學(xué)中的重點和難點安排了13個章節(jié)項目,幫助學(xué)生更好地學(xué)習(xí)教材各章節(jié)中的知識點。項目一:由現(xiàn)實生活中的漢諾塔游戲、交換兩個杯子中飲料的問題,引入一個利用VB程序解決兩幅圖片對換位置的具體案例,使學(xué)生熟悉VB集成開發(fā)環(huán)境以及各種窗口的使用、掌握常用控件對象的建立以及布局、利用VB開發(fā)簡單應(yīng)用程序的步驟、并初步引入程序設(shè)計思想,引導(dǎo)學(xué)生思考兩數(shù)互換的問題,使學(xué)生通過觀察、思考、總結(jié)得出兩數(shù)互換的問題和兩幅圖片互換位置是一類問題。項目二:編寫一程序,在屏幕上顯示“歡迎來到VB世界!”,并輸入自己的名字。使學(xué)生熟悉VB編程四部曲———界面設(shè)計、相關(guān)對象的屬性設(shè)置、相關(guān)對象的代碼編寫、調(diào)試運(yùn)行,尤其注意程序的調(diào)試過程。項目三:設(shè)計一個華氏溫度與攝氏溫度之間轉(zhuǎn)換的程序。通過這個項目熟悉VB的數(shù)據(jù)類型及其運(yùn)算,掌握VB的常用標(biāo)準(zhǔn)函數(shù)、變量以及常量的使用等語法知識點。項目四:利用輸入函數(shù)輸入一元二次方程的系數(shù)a、b、c,編寫程序計算一元二次方程的兩個實根或虛根,用輸出語句輸出結(jié)果。熟悉常用的輸入輸出控件、掌握Print方法、Inputbox()函數(shù)、Msgbox()函數(shù)和Msgbox過程的使用方法。項目五:設(shè)計一個賬號和密碼的輸入檢驗程序。規(guī)范整理英文文章,即對輸入的任意大小寫的英文文章進(jìn)行整理,規(guī)則是:所有句子開頭應(yīng)為大寫字目(句子是以符號“?”、“.”、“!”作為結(jié)束符的),其他都是小寫字母。使學(xué)生熟練掌握程序三大結(jié)構(gòu)中的選擇和循環(huán)結(jié)構(gòu)。項目六:對一個班級的學(xué)生成績進(jìn)行輸入統(tǒng)計,找出所有成績中的最高分和最低分、全班成績的平均分等。使學(xué)生掌握數(shù)組的使用。項目七:編寫一個函數(shù),在已知的字符串中找出最長的單詞。假定已知字符串中只含有字符和空格,空格用來分隔不同的單詞。通過該項目的學(xué)習(xí)使學(xué)生掌握過程程序的設(shè)計、實參、形參等基本概念。項目八:常用控件的使用。設(shè)計一個類似Win-dows記事本的應(yīng)用程序,并完善其各項功能。通過該項目使學(xué)生掌握菜單、對話框和多重窗體程序設(shè)計。項目九:導(dǎo)入手機(jī)號碼文件,編寫一個手機(jī)選號程序,比如說選出手機(jī)尾號后四位相同的手機(jī)號碼等。要求學(xué)生通過學(xué)習(xí),掌握文件的相關(guān)操作,利用文件能夠建立簡單的應(yīng)用程序。項目十:建立本班同學(xué)信息庫,具體包括:學(xué)號、姓名、性別、出生日期、寢室電話、手機(jī)號碼,并用數(shù)據(jù)控件及綁定控件實現(xiàn)對同學(xué)信息的瀏覽,并實現(xiàn)按姓名查詢相關(guān)人員的基本信息。通過該項目掌握VB數(shù)據(jù)庫的相關(guān)技術(shù)。項目十一:設(shè)計多文檔應(yīng)用程序,熟悉VB高級界面的設(shè)計。項目十二:用MMControl控件設(shè)計一個錄音機(jī),用API函數(shù)設(shè)計一個用戶化的CD播放器。通過學(xué)習(xí),使學(xué)生掌握VB多媒體程序設(shè)計。
1.1.2階段項目
為了使整個學(xué)期的教學(xué)內(nèi)容具有連貫性,糅合各章節(jié)零散的知識點,使教學(xué)實踐具有可操作性,將整個學(xué)期的教學(xué)實踐分成了三個階段,每個階段選用一個打破章節(jié)限制的階段項目,使學(xué)生對所學(xué)知識內(nèi)容有一個階段性較完整的認(rèn)識。這三個階段依次是實踐的開始階段、實踐的展開階段、實踐的結(jié)束階段,分別對應(yīng)階段項目一、階段項目二和階段項目三。每個階段中抓住關(guān)鍵教學(xué)環(huán)節(jié),按照“大項目、小案例、任務(wù)驅(qū)動不斷”的具體教學(xué)流程組織教學(xué)。階段項目一:選用簡單的項目,如蝴蝶飛舞、字幕滾動的項目。由于是初次接觸計算機(jī)編程語言,所以對于非計算機(jī)專業(yè)的學(xué)生來說,這門課程的入門學(xué)習(xí)很關(guān)鍵,如果按照常規(guī)授課方法,依據(jù)書本上的章節(jié)內(nèi)容安排依次講授VB語言發(fā)展史、VB語言特點以及編程環(huán)境等內(nèi)容的話,學(xué)生很難接受,往往是聽得稀里糊涂,不知道學(xué)習(xí)VB究竟有什么實際作用,從而會產(chǎn)生畏難情緒,最終導(dǎo)致學(xué)生對VB知識學(xué)習(xí)失去興趣和信心。為消除初學(xué)者的畏難情緒,第一階段主要以激發(fā)學(xué)生的學(xué)習(xí)興趣為主,讓學(xué)生對VB有一個直觀的認(rèn)識,同時讓學(xué)生在輕松的氣氛中了解VB的編程環(huán)境和編程步驟,以及VB面向?qū)ο蟆⑹录?qū)動的編程機(jī)制。萬事開頭難,一旦學(xué)生對VB產(chǎn)生了興趣,就有利于后續(xù)知識的學(xué)習(xí)。階段項目二:難度稍微加大,選用計算器項目。通過本項目,一方面讓學(xué)生理解控件數(shù)組的含義和設(shè)計使用方法,以及簡單下拉菜單、常用數(shù)學(xué)函數(shù)的使用、過程函數(shù)的編寫等,進(jìn)一步加強(qiáng)學(xué)生對概念的理解。另一方面讓學(xué)生注意可視化界面的設(shè)計,因為友好美觀的人機(jī)交互界面,給人賞心悅目感覺的同時是軟件的門面。階段項目三:選用綜合項目———學(xué)生信息管理系統(tǒng)。通過這個項目讓學(xué)生真正了解掌握軟件的開發(fā)過程。雖然這個項目比較難,但是有了前面知識的鋪墊,會變得容易接受理解,也是對前面所學(xué)知識點的一次鞏固和進(jìn)一步更深入的理解,更是對前面知識的綜合應(yīng)用,讓學(xué)生由淺入深、由易到難,逐步領(lǐng)會掌握編程的基本思想、基本方法和開發(fā)一個軟件的完整步驟。三個階段通過運(yùn)用“大項目、小案例”,每個階段讓學(xué)生帶著具體任務(wù)去學(xué)習(xí),把枯燥的理論知識與生動形象的教學(xué)方式相結(jié)合,以清晰簡明的表達(dá)方式深入淺出地向?qū)W生傳授VB程序設(shè)計語言課程的知識,使學(xué)生在完成具體任務(wù)的實踐過程中不斷加深對面向?qū)ο蟪绦蛟O(shè)計思想和知識的理解。
1.2《VB程序設(shè)計》課程中的案例選取
有了已經(jīng)準(zhǔn)備好的各模塊的項目,并展示給學(xué)生,學(xué)生有了興趣后,就會想這些項目是怎么完成的,任務(wù)就落到各個模塊項目里面具體的案例上了。由于VB程序設(shè)計授課內(nèi)容多,授課時間緊張,按各知識模塊劃分選取項目后,在每個項目里面,按項目選取具體案例或是進(jìn)行設(shè)計各項目的各功能模塊,各功能模塊實際就是一個個案例。在教學(xué)過程中應(yīng)循序漸進(jìn),可以在原有案例的基礎(chǔ)上逐步改變或增加一些條件,將應(yīng)用進(jìn)行引申,啟發(fā)學(xué)生思維,讓學(xué)生對知識點的理解更透徹,掌握各知識點之間的聯(lián)系,提高學(xué)生發(fā)現(xiàn)問題、解決問題的能力,并在教學(xué)中兼顧學(xué)生生活經(jīng)驗與知識趣味性,達(dá)到事半功倍的教學(xué)效果。
1.3任務(wù)設(shè)計
圍繞每一知識模塊的教學(xué)內(nèi)容、教學(xué)知識點,設(shè)計相關(guān)的項目,并在各個項目中采用了系列案例以及完成各功能模塊的案例,為了讓學(xué)生更加熟練、更好地掌握教學(xué)內(nèi)容,在各知識模塊的學(xué)習(xí)中設(shè)置學(xué)習(xí)情景,給學(xué)生留有感興趣的任務(wù),讓學(xué)生去完成。同時根據(jù)各知識模塊提出了單元任務(wù),單元任務(wù)設(shè)置兩個層次———基本任務(wù)和提高任務(wù)。由于學(xué)生自身水平有差異,對于基礎(chǔ)好、學(xué)有余力的學(xué)生,要求他們不但要完成基本任務(wù),還要完成提高任務(wù);對于大多數(shù)學(xué)生,只要求他們完成基本任務(wù)。由于時間的限制,可以讓學(xué)生在課余時間分析任務(wù),在上機(jī)實踐課以及課余時間去完成任務(wù),最后做任務(wù)的總結(jié)。有了興趣和任務(wù)的驅(qū)使,學(xué)生為了完成任務(wù),就會利用各種方式和手段積極主動地去解決問題,他們會通過查閱相關(guān)書本、瀏覽網(wǎng)絡(luò)資源、同學(xué)之間互相協(xié)作等方式解決問題,充分調(diào)動了學(xué)生的主觀能動性,在完成任務(wù)的過程中學(xué)生分析問題、解決問題、實際開發(fā)應(yīng)用程序的能力得到了鍛煉,為學(xué)生知識的創(chuàng)新奠定良好的基礎(chǔ),同時知識面也更廣、更大了。學(xué)生不會再覺得教學(xué)只是教師一個人的“獨(dú)角戲”,而是教師和學(xué)生的“二人轉(zhuǎn)”。在相互的配合以及友好和諧的師生關(guān)系中,教學(xué)順利完成的同時學(xué)生個人的知識庫也得到了構(gòu)建。
2實施方法
關(guān)鍵詞:PCI總線設(shè)備驅(qū)動程序WDM模式DriverStudio
PCI總線規(guī)范是為提高微機(jī)總線的數(shù)據(jù)傳輸速度而制定的一種局部總線標(biāo)準(zhǔn)。在設(shè)計自行開發(fā)的基于PCI總線的數(shù)據(jù)傳輸設(shè)備時,需要開發(fā)相應(yīng)的設(shè)備驅(qū)動程序。通常開發(fā)PCI設(shè)備驅(qū)動程序有多種模式,在Windows2000環(huán)境下,主要采用WDM模式。本文針對自行開發(fā)的基于PCI總線的CCD視頻信號傳輸控制卡,編寫了符合WDM模式的驅(qū)動程序。
1WDM模式驅(qū)動程序
1.1WDM模式(WindowsDriverModel)
Windows2000對驅(qū)動程序的編寫不再基于以往的Win3.x和Win9x下的VxD(虛擬設(shè)備驅(qū)動程序)結(jié)構(gòu),而是基于一種新的驅(qū)動模型——WDM(WindowsDriverModel)。
WDM為Windows98/2000/XP操作系統(tǒng)的設(shè)備驅(qū)動程序的設(shè)計提供了統(tǒng)一的框架。WDM來源于WindowsNT的分層32位設(shè)備驅(qū)動程序模型(layered32-bitdevicedrivermodel)。它支持更多的特性,如即插即用(PnP)、電源管理、WMI和NT事件。
1.2設(shè)備驅(qū)動程序
設(shè)備驅(qū)動程序是操作系統(tǒng)的一個組成部分,它由I/O管理器(I/OManager)管理和調(diào)動。Windows2000操作系統(tǒng)下的I/O管理器功能描述如圖1所示。
I/O管理器每收到一個來自用戶應(yīng)用程序的請求就創(chuàng)建一個I/O請求包(IRP)的數(shù)據(jù)結(jié)構(gòu),并將其作為參數(shù)傳遞給驅(qū)動程序。驅(qū)動程序通過識別IRP中的物理設(shè)備對象(PDO)來區(qū)別是發(fā)送給哪一個設(shè)備。IRP結(jié)構(gòu)中存放請求的類型、用戶緩沖區(qū)的首地址、用戶請求數(shù)據(jù)的長度等信息。驅(qū)動程序處理完這個請求后,在該結(jié)構(gòu)中填入處理結(jié)果的有關(guān)信息,調(diào)用IoCompleteRequest將其返回給I/O管理器,用戶應(yīng)用程序的請求隨即返回。訪問硬件時,驅(qū)動程序通過調(diào)用硬件抽象層的函數(shù)實現(xiàn)。
1.3DriverStudio工具簡介
NuMegaLab公司開發(fā)的DriverStudio是一整套開發(fā)、調(diào)試和檢測Windows平臺下設(shè)備驅(qū)動程序的工具軟件包。它把DDK(DeviceDevelopmentKit)封裝成完整的C++函數(shù)庫,根據(jù)具體硬件通過向?qū)煽蚣艽a,并且提供了一套完整的調(diào)試和性能測試工具SoftICE、DriverMonitor等。
2應(yīng)用實例
本文利用PCI專用接口芯片PCI9052設(shè)計了一個數(shù)據(jù)傳輸控制卡。卡上主要的芯片有PCI9052、FIFO(CY7C4221)、CPLD(MAX7064S)和A/D轉(zhuǎn)換器(MAX1197)。傳輸卡硬件框圖如圖2所示。面陣CCD得到的視頻信號經(jīng)過調(diào)理電路,生成的視頻調(diào)理信號通過A/D轉(zhuǎn)換器進(jìn)行數(shù)字化處理,送入FIFO中。在CPLD的控制下,數(shù)據(jù)經(jīng)過PCI9052送入PCI總線,再傳送到計算機(jī)內(nèi)存中,并顯示在監(jiān)視器上。驅(qū)動程序必須實現(xiàn)如下幾個基本功能:(1)硬件中斷;(2)能支持應(yīng)用程序獲取數(shù)據(jù);(3)能根據(jù)外部FIFO(CY7C4221)的狀態(tài)啟動或停止突發(fā)傳輸。
在數(shù)據(jù)輸入過程中,最重要的是對數(shù)據(jù)進(jìn)行實時控制,因此需要硬件中斷。在中斷程序中,根據(jù)外部FIFO狀態(tài)完成數(shù)據(jù)的讀入。
2.1用DriverWizard生成驅(qū)動程序框架
DriverStudio中的DriverWorks軟件為開發(fā)WDM程序提供了一個完整的框架。它包含一個可快速生成WDM驅(qū)動程序框架的代碼生成向?qū)Чぞ逥riverWizard,而且還帶有許多類庫。在用DriverWizard生成的程序框架中寫入相對于設(shè)備的特定代碼,編譯后即可得到所需的驅(qū)動程序。
在利用DriverWorksV2.7的向?qū)riverWizard完成驅(qū)動程序的框架時共有11個步驟,其中關(guān)鍵步驟有:
(1)在第四步中選中PCI,并在VendorID和DeviceID中分別輸入廠商號和設(shè)備號,還需填入PCISubsystemID和PCIRevisionID。這四項可以用網(wǎng)上的免費(fèi)軟件PCITree或PCIView瀏覽PCI設(shè)備,用這兩個軟件也可以得到BAR0~BAR5的資源分配情況和中斷號。
(2)第七步IRP隊列排隊方法,它決定了驅(qū)動程序檢查設(shè)備的方式。本設(shè)計選SystemManaged,則所有的IRP排隊都由系統(tǒng)(即I/O管理器)完成。
(3)第九步是最關(guān)鍵的一步。首先在Resources中添加資源,在name中輸入變量名,在PCIBaseAddress中輸入0~5的序列號。0~5和BAR0~BAR5一一對應(yīng)。在設(shè)置中斷對話框中,在name欄寫入中斷服務(wù)程序的名稱,選中創(chuàng)建中斷服務(wù)程序ISR?穴CreateISR?雪,不選創(chuàng)建延遲程序調(diào)用DPC(CreateDPC),選中MakeISR/DPCclassfunctions,使ISR/DPC成為設(shè)備類的成員函數(shù)。
其次選中Buffer以選取讀寫方式,用于描述與I/O操作相關(guān)的數(shù)據(jù)緩沖區(qū)。本設(shè)計需要快速傳送大量數(shù)據(jù),因此采用DirectI/O方式。
(4)在第十步中,需要加入與應(yīng)用程序或者其他驅(qū)動程序通信的I/O控制代碼參量。
2.2驅(qū)動程序模塊框圖和代碼分布
PCI設(shè)備驅(qū)動程序模塊包括配置空間的訪問模塊、IO端口模塊、內(nèi)存讀寫模塊和終端模塊等。各模塊之間是對等的。驅(qū)動程序模塊框圖如圖3所示。
驅(qū)動程序初始化模塊代碼段放在#pragmacode_seg(″INT″)和#pragmacode_seg()之間。在系統(tǒng)初始化完成后,這部分代碼從內(nèi)存中釋放,防止占用系統(tǒng)寶貴的內(nèi)存資源。#pragmacode_seg()之后是驅(qū)動程序和系統(tǒng)的許多模塊的實現(xiàn)部分。這部分在驅(qū)動程序運(yùn)行后不會從內(nèi)存中釋放。
2.3驅(qū)動程序主要模塊的實現(xiàn)
(1)配置空間的訪問模塊
DriverWorks的KPciConfiguration類封裝了訪問PCI設(shè)備配置空間的所有操作。首先初始化這個類的實例:
KpciConfigurationPciConfig()m_Lower.TopOfStack());
/?觹m_Lower是KpnpLowerDevice類的對象。m_LowerTopOfStack()返回當(dāng)前設(shè)備堆棧頂部的設(shè)備對象。*/
初始化完后可以直接利用成員函數(shù)ReadHeader/WriteHeader函數(shù)訪問所有的配置寄存器。
為了確定映射空間的類型和大小,先向目標(biāo)基地址寄存器寫入0Xffffffffh,然后回讀該寄存器的值。如果最低位為1,表示映射于I/O空間,反之為存儲空間;如果映射于存儲空間,從第四位開始計算0的個數(shù)可以確定內(nèi)存空間的大小;如果是I/O方式,從第二位開始計算0的個數(shù)可確定I/O空間的大小,最大為256字節(jié)。如果設(shè)備的存儲空間超過256字節(jié),要實現(xiàn)設(shè)備的整個存儲部分的訪問,就必須采用內(nèi)存映射。
(2)I/O操作模塊
Driverworks的KIoRange類封裝了I/O端口訪問的操作。部分代碼如下:
{……
KIORangeDevIoPort();//創(chuàng)建實例
NTSTATUSstatus=DevIoPort().Initialize(pResListTranslated,pResListRaW,PciConfig.BaseAddressIndexToOrdinal(0));
/*第一個參數(shù)為轉(zhuǎn)換后的資源列表指針;第二個參數(shù)為原始資源列表指針;第三個參數(shù)中的0為I/O口對應(yīng)的基地址,用來轉(zhuǎn)換成特定端口資源的序數(shù)?*/
If(NT_SUCCESS(status))
{……
DevIoPort.inb(0,LineBuf1,10);
/*成功初始化后可分別用KIoRange類的成員函數(shù)inb(/outb)從端口中讀/寫字節(jié)*/
}
else{Invalidate();returnstatus;
/*未能初始化成功,錯誤信息在status中*/
{
……}
(3)內(nèi)存讀寫模塊
DriverWorks的KMemoryRange類封裝了端口訪問的操作。
status=m_M(jìn)emoryRange().Initialize(pResListTranslated,pResListRaw,PciConfig.BaseAddressIndexToOrdinal(0));
此函數(shù)的參數(shù)、意義及具體用法與I/O端口的操作基本相同。
內(nèi)存對象也用來發(fā)送控制字,以控制CPLD的開始和停止等。實際上控制字是通過PCI9052發(fā)送的。該控制字地址已被映射成PCI的內(nèi)存空間。所以定義一個指向內(nèi)存空間的內(nèi)存對象,通過該對象即可發(fā)送控制字。
(4)中斷模塊
在中斷模塊,首先要激活PCI9052中斷使能位,然后判斷硬件中斷響應(yīng)是否產(chǎn)生,如果有,則進(jìn)行突發(fā)傳輸,讀入FIFO中的數(shù)據(jù)。
BOOLEANTranCard::Isr_M(jìn)yIrq(void)
{if(//中斷未產(chǎn)生)
{……
returnFALSE;}
else
{/*如果產(chǎn)生硬件中斷,設(shè)置命令寄存器,進(jìn)行突發(fā)數(shù)據(jù)傳輸*/
returnTRUE;}
}
為了將硬件中斷與編寫的中斷服務(wù)程序連接在一起,采用InitializeAndConnect方法,部分代碼如下:
NTSTATUSTranCardDevice?押?押OnStartDevice(KIrpI)
{……
status=m_M(jìn)yIrq.InitializeAndConnect(
pResListTranlated,
LinkTo(Isr_M(jìn)yIrq),
This;)
……}
2.4驅(qū)動程序的調(diào)用
編寫驅(qū)動程序本身不是最終目的,最終目的是調(diào)用驅(qū)動程序管理資源,并為用戶應(yīng)用程序使用。驅(qū)動程序加載以后,它的許多進(jìn)程處于Idle狀態(tài),實際上需要用戶應(yīng)用程序去調(diào)用激活。應(yīng)用程序利用Win32API直接調(diào)用驅(qū)動程序,實現(xiàn)驅(qū)動程序和應(yīng)用程序的信息交互。
首先用CreateFile()打開設(shè)備,獲得一個指向設(shè)備對象的句柄。使用CreateFile函數(shù)時應(yīng)注意:由于驅(qū)動程序是*.sys,所以第一個參數(shù)應(yīng)該是這個設(shè)備對象的標(biāo)志連接(symboliclink)。該標(biāo)志連接名有一個設(shè)置數(shù)據(jù)文件搜索路徑的數(shù)字號,而這個數(shù)字號通常是零。如果這個連接名是″TranCard″,則傳遞給CreateFile的宇符串就是:″\\\\.\\TranCard0″。例如:
HANDLEhDevice=CreateFile(″\\\\.\\TranCard0″)GENERIC_READ|GENERIC_WRITE,FILE_SHARE_READ,NULL?,OPEN_EXISTING,0,NULL);
然后用DeviceIoControl()進(jìn)行數(shù)據(jù)的傳送。最后用CloseHandle()關(guān)閉設(shè)備句柄。
下面是應(yīng)用DeviceIoControl()程序片段。
{……
m_b=DeviceIoControl(hDevice,TRANCARD_IOCTL_
RECEIVE(buffer,sizeof,buffer,NULL,0,&buffersize,NULL);
……}
2.5驅(qū)動程序的調(diào)試
采用SoftICE、DriverMonitor作為調(diào)試工具,基本調(diào)試過程如下:(1)使用symbolloader加載驅(qū)動程序,然后使用SoftICE跟蹤調(diào)試,確認(rèn)驅(qū)動程序正常加載;(2)對核心的中斷響應(yīng)程序代碼,用SoftICE中的Genint命令產(chǎn)生虛擬中斷,單步跟蹤中斷;(3)硬件發(fā)送大量的數(shù)據(jù),通過查看內(nèi)存的數(shù)據(jù),確認(rèn)數(shù)據(jù)傳輸是否正確。
西安理工大學(xué)工科非計算機(jī)專業(yè)和計算機(jī)專業(yè)雖然都開設(shè)C語言程序設(shè)計課程,但是前者具有鮮明的專業(yè)特點,對該課程的要求明顯不同,僅僅按照“面向?qū)ο蠼虒W(xué)”的原則,適當(dāng)調(diào)整教學(xué)組織活動和教學(xué)內(nèi)容對于后者是遠(yuǎn)遠(yuǎn)不夠的。針對目前工科非計算機(jī)專業(yè)C語言程序設(shè)計課程教學(xué)實踐中所暴露的主要問題,筆者積極開展了非計算機(jī)專業(yè)C語言程序設(shè)計課程教學(xué)設(shè)計的教改工作。
1.1教學(xué)設(shè)計概述
所謂教學(xué)設(shè)計,就是為了達(dá)到一定的教學(xué)目的,對教什么(課程、教學(xué)內(nèi)容等)和怎么教(組織、方法、媒體的使用等)進(jìn)行設(shè)計。教學(xué)設(shè)計不等同于傳統(tǒng)的備課寫教案。教學(xué)設(shè)計有利于教學(xué)工作的科學(xué)化,使教學(xué)活動納入科學(xué)的軌道。教學(xué)設(shè)計的意義就在于追求教學(xué)效果的最優(yōu)化,不僅關(guān)心教師如何教,更關(guān)心學(xué)生如何學(xué),注重將人類對教與學(xué)的研究結(jié)果和理論綜合應(yīng)用于教學(xué)實踐。教學(xué)設(shè)計主要包括確定教學(xué)目標(biāo)、組織教學(xué)內(nèi)容、分析教學(xué)對象、選擇教學(xué)形式和方法及教學(xué)媒體、設(shè)計教學(xué)過程、教學(xué)質(zhì)量評價設(shè)計等基本環(huán)節(jié),其中,設(shè)計教學(xué)過程是課程教學(xué)設(shè)計的核心。
1.2該課程教學(xué)設(shè)計的內(nèi)容
西安理工大學(xué)C語言程序設(shè)計課程組于2003年出版了《C語言程序設(shè)計教程》及配套的《C語言程序設(shè)計教程上機(jī)實驗與學(xué)習(xí)指導(dǎo)》特色教材。自2011年開始,非計算機(jī)專業(yè)選用的教材與計算機(jī)專業(yè)不同。目前非計算機(jī)專業(yè)選用《C語言程序設(shè)計》(第1版,張毅坤教授,高等教育出版社,2011)作為該課程的教材。非計算機(jī)專業(yè)C語言程序設(shè)計的教學(xué)設(shè)計是一項復(fù)雜的系統(tǒng)工程,主要包括課程教學(xué)設(shè)計、章節(jié)教學(xué)設(shè)計、課堂教學(xué)設(shè)計和實驗教學(xué)設(shè)計,以西安理工大學(xué)C語言程序設(shè)計課程教學(xué)大綱為指導(dǎo),以《C語言程序設(shè)計》(第1版)及其配套教材為基礎(chǔ),確定課程教學(xué)設(shè)計的內(nèi)容:①將該課程的教學(xué)目標(biāo)確定為“掌握C語言的基本語法和語義,理解結(jié)構(gòu)化程序設(shè)計的思想和方法,提高學(xué)生的編程能力和調(diào)試程序的能力”。②組織教學(xué)內(nèi)容的關(guān)鍵是進(jìn)行教材的組織呈現(xiàn),理論教學(xué)內(nèi)容包括《C語言程序設(shè)計》(第1版)的第一章至第八章,實驗教學(xué)體現(xiàn)于該教材的第九章及配套教材。③學(xué)生作為教學(xué)對象始終是教學(xué)過程中的重要角色,工科非計算機(jī)專業(yè)的種類多,分析教學(xué)對象就是掌握學(xué)生特點與了解專業(yè)背景并重。④重點突出課堂教學(xué)設(shè)計,傳統(tǒng)教學(xué)與案例教學(xué)有機(jī)結(jié)合,“講解+多媒體演示+課堂板書”缺一不可。⑤設(shè)計教學(xué)過程與“組織教學(xué)內(nèi)容”聯(lián)系最為緊密,主要包括課堂教學(xué)設(shè)計和實驗教學(xué)設(shè)計,教學(xué)過程設(shè)計遵循的總原則是:激發(fā)學(xué)生興趣,注重能力培養(yǎng),合理安排教學(xué)順序,講清重點與化解難點緊密結(jié)合,課堂提高與課后鞏固拓展有機(jī)統(tǒng)一,并預(yù)測教學(xué)實踐中可能出現(xiàn)的意外情況。⑥將學(xué)生評價、同行評價、教學(xué)督導(dǎo)組專家評價、主管教學(xué)的領(lǐng)導(dǎo)評價和教師自我評價這幾種評價的結(jié)果綜合起來,比較客觀的評價教學(xué)效果與教學(xué)質(zhì)量。
2教學(xué)設(shè)計的實踐及效果
我們連續(xù)多年承擔(dān)非計算機(jī)專業(yè)C語言程序設(shè)計課程,先后承擔(dān)過西安理工大學(xué)電氣工程及其自動化(電力)、水文與水資源工程、印刷工程、包裝工程和材料科學(xué)與工程等專業(yè)的C語言程序設(shè)計的理論教學(xué)和實驗教學(xué)任務(wù)。始終將上述教學(xué)設(shè)計的內(nèi)容貫穿于課堂教學(xué)和實驗教學(xué)之中。C語言程序設(shè)計本身是一門實踐性很強(qiáng)的課程,加之各個理工科專業(yè)的特色鮮明,所以結(jié)合學(xué)生所學(xué)專業(yè)特點與需求,同一門課程,針對不同專業(yè)的學(xué)生,適當(dāng)調(diào)整教學(xué)設(shè)計內(nèi)容,并在教學(xué)實踐中檢驗教學(xué)效果。2012年以來,學(xué)生對筆者的教學(xué)評分一直在95分以上,也給予了肯定性的評價,例如“采用啟發(fā)式教學(xué),闡述問題深入淺出,重點突出,能理論聯(lián)系實際或聯(lián)系學(xué)科發(fā)展的新成果”;“對于您的授課方式我們很滿意,感謝您對這門課程的熱忱,我們會努力學(xué)下去”;等等。
3結(jié)語