在线看毛片网站电影-亚洲国产欧美日韩精品一区二区三区,国产欧美乱夫不卡无乱码,国产精品欧美久久久天天影视,精品一区二区三区视频在线观看,亚洲国产精品人成乱码天天看,日韩久久久一区,91精品国产91免费

<menu id="6qfwx"><li id="6qfwx"></li></menu>
    1. <menu id="6qfwx"><dl id="6qfwx"></dl></menu>

      <label id="6qfwx"><ol id="6qfwx"></ol></label><menu id="6qfwx"></menu><object id="6qfwx"><strike id="6qfwx"><noscript id="6qfwx"></noscript></strike></object>
        1. <center id="6qfwx"><dl id="6qfwx"></dl></center>

            新聞中心

            EEPW首頁 > 嵌入式系統(tǒng) > 設計應用 > RFID安檢系統(tǒng)的嵌入式Linux解決方案

            RFID安檢系統(tǒng)的嵌入式Linux解決方案

            作者: 時間:2011-05-09 來源:網絡 收藏

              3.3 串口同sqlite3通信測試與分析

              為了驗證sqlite3數(shù)據(jù)庫在[3-4]終端下的執(zhí)行效率和穩(wěn)定性,為此做了一個簡單的測試實驗:通過上位機程序向終端的串口定時發(fā)送字符串;終端接收到字符串便立即寫入到下位機的數(shù)據(jù)庫中。自后查看數(shù)據(jù)中的數(shù)據(jù),看看有沒有遺漏和誤碼。上位機的程序使用VC6.0開發(fā),整個程序界面只設了一個按鍵,按下按鍵,上位機就向嵌入式Linux終端不停地發(fā)送字符串數(shù)據(jù),按鍵響應程序設計如下:

            void CSendDlg::OnButton_Click()
            {
            state=1;
            while(1)
            {
            str.Format(第%3d條記錄,state);//格式化字符串格式
            m_Port.WriteToPort(str,str.GetLength());//向串口發(fā)送字符串
            state++;
            Sleep(100);//延時100 ms
            }
              可見程序是個定時100 ms便發(fā)送一條字符串的循環(huán),而且發(fā)送的每一條字符串事先通過str.Format格式化為固定長度,本例中是11 B。按下按鍵后發(fā)送的第一條字符串為:“第1條記錄”,每發(fā)送一條字符串里面的數(shù)字加“1”,這樣寫到數(shù)據(jù)庫中就可以很清楚地查看有沒有遺漏和誤碼,而且可以通過修改Sleep函數(shù)的延時參數(shù)檢測出嵌入式Linux終端下sqlite3數(shù)據(jù)庫操作的速度。

              下位機嵌入式Linux終端的程序設計為:先創(chuàng)建一個數(shù)據(jù)庫文件test.db,接著就是一個死循環(huán),串口不停地查找有沒有數(shù)據(jù)寫入,當檢測到數(shù)據(jù)時,便寫入到test.db中,若寫入有誤,則立即跳出循環(huán),終止程序。
            char sql[100]=create table receive(name varchar(40));
            qlite3_open(/var/sd/test.db,db); //在SD卡中創(chuàng)建
            test.db文件
            sqlite3_exec(db,sql,0,0,errmsg); //在test.db文件中插入
            表receiver
            fd=open_port(fd,1)//打開串口1
            set_opt(fd,9600,8,'N',1)//配置串口屬性,開始通信
            while(1)
            {
            n=0;
            i=0;
            bzero(read_buf, sizeof(read_buf));
            if( (n=read(fd, read_buf, sizeof(read_buf))) =0)
            Continue;//未讀到數(shù)據(jù)則繼續(xù)查找串口
            printf(recever %d wordsn,n);//輸出讀到的字符數(shù)
            sprintf(sql,insert into receive values(%s),read_buf);
            result =sqlite3_exec(db,sql,0,0,errmsg);//插入數(shù)據(jù)
            到數(shù)據(jù)庫中
            if(result==SQLITE_OK)
            printf(第%3d條數(shù)據(jù)寫入成功n,++i);
            //若插入成功則提示
            else break;//若插入不成功,則跳出循環(huán)
            }

              整個測試根據(jù)上位機串口發(fā)送的頻率不同做了多組實驗,每組實驗寫入1 000個數(shù)據(jù),最終結果分析如下:上位機在定時80 ms左右或大于80 ms的情況下發(fā)送數(shù)據(jù)時,數(shù)據(jù)庫寫入的誤碼率為零;當定時時間小于80 ms時,隨著定時時間變小誤碼率會越來越高。通過數(shù)據(jù)分析可知原因有以下幾點:一是數(shù)據(jù)庫本身寫入需用時幾十毫秒,二是SD卡并非高速讀寫設備,當數(shù)據(jù)還未完全寫入數(shù)據(jù)庫時若有新數(shù)據(jù)發(fā)過來,則下次讀寫將會發(fā)生難以估計的錯誤。實驗還得出了當把數(shù)據(jù)庫文件寫入到Flash上的總耗時約為50 ms,比寫入SD卡中約少30 ms。不過就80 ms左右的一次讀寫速度而言,嵌入式數(shù)據(jù)庫sqlite3執(zhí)行效率和穩(wěn)定性非??捎^,現(xiàn)在一般的讀寫器通過串口執(zhí)行一條指令的時間也需幾十毫秒的時間,因而使用sqlite3數(shù)據(jù)庫在執(zhí)行速率和穩(wěn)定性上對于讀寫數(shù)據(jù)的處理可以很好地達到要求,而且sqlite3還支持數(shù)據(jù)加密,安全性同樣非常出色。

            linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)

            上一頁 1 2 3 下一頁

            評論


            相關推薦

            技術專區(qū)

            關閉