1 引 言
串行通訊是計算機與其他設(shè)備進行數(shù)據(jù)交換時經(jīng)常使用的方法之一,他具有實現(xiàn)簡單,使用靈活方便,數(shù)據(jù)傳輸可靠等優(yōu)點,因而在工業(yè)監(jiān)控、數(shù)據(jù)采集和實時監(jiān)控系統(tǒng)中得到廣泛應用.
高速串口數(shù)據(jù)采集軟件的設(shè)計不同于普通串口通信,其要求在接收數(shù)據(jù)采集設(shè)備發(fā)送大量數(shù)據(jù)的同時完成對已接受到數(shù)據(jù)的實時存儲,如果處理不好二者之間的關(guān)系,會造成數(shù)據(jù)的缺失甚至程序的崩潰.這就要求應用程序能夠同時處理兩件以上不同的任務.Win32是基于線程的搶先式多任務操作系統(tǒng),使得應用程序能夠同時執(zhí)行多個任務,即在一個進程中可以同時運行多個線程.一個線程是指程序的一條執(zhí)行路徑,系統(tǒng)不停的在多個線程之間切換.由于時間很短,看上去多個線程在同時運行.對于通訊這種需要花費大量時間來測試I/O操作,同時又要保持響應用戶其它操作的應用程序來說,創(chuàng)建多線程是最佳選擇.
2 系統(tǒng)結(jié)構(gòu)
系統(tǒng)的組成結(jié)構(gòu)如圖1所示.中央控制PC機是系統(tǒng)的核心,要求數(shù)據(jù)采集軟件具有良好的穩(wěn)定性和兼容性.所以獨立設(shè)計了一套基于Visual C++ 6.0的多線程通訊軟件,它與前端的掃描儀串口通信是典型的主從式,在硬件上通過MOXA公司的串口卡實現(xiàn)500K波特的采集速率.
?
3 用MSComm控件實現(xiàn)高速串口數(shù)據(jù)采集的問題
MSComm控件在串口編程時非常方便,程序員不必花時間去了解較為復雜的API函數(shù),只需要在串口通信資源的屬性(Properties)一項中配置串口,串口通信的波特率、數(shù)據(jù)位數(shù)、停止位數(shù)、奇偶校驗、發(fā)送緩沖區(qū)大小、接收緩沖區(qū)大小以及超時設(shè)置等均在此時進行配置.完成串口配置之后即可打開串口,進行數(shù)據(jù)讀寫.
對于一般數(shù)據(jù)交換及串口通信來說,MSComm控件完全能夠滿足要求.但由于控件本身對于接收緩沖區(qū)大小設(shè)置的限定,為高速數(shù)據(jù)采集軟件的設(shè)計帶來了麻煩.如果接收緩沖區(qū)不能滿足設(shè)計的要求,當緩沖區(qū)內(nèi)數(shù)據(jù)達到消息響應值并響應存儲命令時,而新采集的數(shù)據(jù)傳輸速度大于已接收到數(shù)據(jù)的存儲速度,就會造成接收緩沖區(qū)的溢出,直接導致系統(tǒng)的崩潰.這一點在程序設(shè)計初期深有體會.
在程序設(shè)計時也嘗試當緩沖區(qū)達到閾值響應消息時,在消息響應中啟動一個新的線程,先將緩沖區(qū)中接收到的數(shù)據(jù)取出到新開辟的內(nèi)存單元中,再進行數(shù)據(jù)存儲.程序可以運行,但出現(xiàn)了新的問題,即有的數(shù)據(jù)幀中的數(shù)據(jù)發(fā)生丟失.分析產(chǎn)生這種數(shù)據(jù)丟失的原因,還是由于控件本身對于接收緩沖區(qū)大小設(shè)置的限定.
4 程序設(shè)計創(chuàng)新
4.1多線程程序設(shè)計思想
在32位Windows系統(tǒng)中,術(shù)語多任務是指系統(tǒng)可以同時運行多個進程,而每個進程也可以同時執(zhí)行多個線程.進程就是應用程序的運行實例.每個進程都有自己私有的虛擬地址空間,每個進程都有一個主線程,但可以建立另外的線程.進程中的線程是并行執(zhí)行的,每個線程占用CPU的時間由系統(tǒng)來劃分.
可以把線程看作是操作系統(tǒng)分配CPU時間的基本實體,系統(tǒng)不停的在各個線程之間切換,它對線程的中斷是匯編語言級的.系統(tǒng)為每一個線程分配一個CPU時間段,某個線程只有在分配的時間段內(nèi)才有對CPU的控制權(quán).
進程中所有的線程共享進程的虛擬地址空間,這意味著所有線程都可以訪問進程的全局變量和資源.這一方面為編程帶來了方便,但另一方面也容易造成沖突.雖然在進程中進行費時的工作不會導致系統(tǒng)的掛起,但會導致進程本身的掛起.所以,如果進程即要進行長期工作,又要響應用戶的輸入,那么它可以啟動一個線程來專門負責費時的工作,而主線程仍然可以與用戶進行交互.由此可見,利用Win32的重疊I/O操作和多線程特性,可以編出高效的通信程序.
高速串口數(shù)據(jù)采集軟件的特點是接收數(shù)據(jù)的速度要求很高,接收數(shù)據(jù)量很大,而控制掃描儀發(fā)送的命令字數(shù)據(jù)量很小.根據(jù)這些特性,可以在程序中創(chuàng)建一個輔助工作者線程專門來監(jiān)視串行口的輸入.由于寫串口的數(shù)據(jù)量不大,不會太費時,所以在主線程中完成寫端口的任務是可以的,不必另外創(chuàng)建線程.
評論
查看更多