一種實(shí)時(shí)數(shù)據(jù)采集與存儲(chǔ)系統(tǒng)的實(shí)現(xiàn)方法
3.4 多線程的實(shí)時(shí)數(shù)據(jù)存儲(chǔ)軟件設(shè)計(jì)
在要求高速、實(shí)時(shí)和連續(xù)采集和存儲(chǔ)的情況下,一方面要求系統(tǒng)不間斷地進(jìn)行數(shù)據(jù)采集,同時(shí)還要進(jìn)行數(shù)據(jù)實(shí)時(shí)地存儲(chǔ),否則將會(huì)丟失數(shù)據(jù),造成數(shù)據(jù)不完整。為了解決這個(gè)問題,我們?cè)谲浖?a class="contentlabel" href="http://www.ex-cimer.com/news/listbylabel/label/實(shí)現(xiàn)">實(shí)現(xiàn)中,引入了Windows的多任務(wù)處理技術(shù)(multitasking)。在程序里創(chuàng)建兩個(gè)工作線程分別完成數(shù)據(jù)采集和數(shù)據(jù)存儲(chǔ)工作。緩沖方式采用上面所說雙緩沖區(qū)模式,當(dāng)數(shù)據(jù)采集線程(SampleThreadProc)把采集到的數(shù)據(jù)寫入第一緩沖區(qū)時(shí),數(shù)據(jù)存儲(chǔ)線程(StorageThreadProc)把第二緩沖區(qū)的數(shù)據(jù)存入SCSI硬盤;當(dāng)數(shù)據(jù)采集線程把數(shù)據(jù)寫入第二緩沖區(qū)時(shí),數(shù)據(jù)存儲(chǔ)線程把第一緩沖區(qū)的數(shù)據(jù)存入SCSI硬盤;如此循環(huán)。另外通過實(shí)際實(shí)驗(yàn)測(cè)試Adaptec19160Ultra160-SCSI硬盤控制器,配合希捷公司出品的ST3146707LCSCSI硬盤,持續(xù)寫入速率能達(dá)到80Mbytes/sec。遠(yuǎn)大于45Mbytes/sec的采集速率。所以當(dāng)數(shù)據(jù)采集線程寫滿其中一個(gè)緩沖區(qū)之前,數(shù)據(jù)存儲(chǔ)線程已經(jīng)把另一個(gè)緩沖區(qū)里的數(shù)據(jù)存儲(chǔ)入SCSI硬盤。所以這種方法能保證數(shù)據(jù)的實(shí)時(shí)性、完整性和連續(xù)性。其程序流程圖如圖1。
評(píng)論