導航:首頁 > 網路數據 > delphi線程接收串口大資料庫

delphi線程接收串口大資料庫

發布時間:2023-07-11 22:22:37

① delphi如何讀取串口(com)

Delphi是一種具有功能強大、簡便易用和代碼執行速度快等優點的可視化快速應用開發工具,它在構架企業信息系統方面發揮著越來越重要的作用,許多程序員願意選擇 Delphi作為開發工具編制各種應用程序。但是,美中不足之處是 Delphi沒有自帶的串口通信控制項,在它的幫助文檔里也沒有提及串口通信,這就給編制通信程序的開發人員帶來許多不便。

目前,利用 Delphi實現串口通信的常用的方法有 3種:一是利用控制項,如 MSCOMM控制項和 SPCOMM控制項;二是使用 API函數;三是調用其他串口通信程序。其中利用 API編寫串口通信程序較為復雜,需要掌握大量的通信知識。相比較而言,利用 SPCOMM控制項則相對較簡單,並且該控制項具有豐富的與串口通信密切相關的屬性及事件,提供了對串口的各種操作,而且還支持多線程。下面本文結合實例詳細介紹 SPCOMM控制項的使用。

SPCOMM的安裝

1.選擇下拉菜單 Component中的 Install Component選項,彈出如圖 1所示的窗口。

圖 1

在 Unit file name處填寫 SPCOMM控制項所在的路徑,其他各項可用默認值,點擊 OK按鈕。

2.安裝後,在 System控制項面板中將出現一個紅色控制項 COM。現在就可以像 Delphi自帶控制項一樣使用 COM控制項了。

SPCOMM的屬性、方法和事件

1.屬性

●CommName:表示 COM1、 COM2等串口的名字;

●BaudRate:根據實際需要設定的波特率,在串口打開後也可更改此值,實際波特率隨之更改;

●ParityCheck:表示是否需要奇偶校驗;

●ByteSize:根據實際情況設定的位元組長度;

●Parity:奇偶校驗位;

●StopBits:停止位;

●SendDataEmpty:這是一個布爾型屬性,為 true時表示發送緩存為空,或者發送隊列里沒有信息;為 false時表示發送緩存不為空,或者發送隊列里有信息。

2.方法

●Startcomm方法用於打開串口,當打開失敗時通常會報錯。錯誤主要有 7種:⑴串口已經打開;⑵打開串口錯誤;⑶文件句柄不是通信句柄;⑷不能夠安裝通信緩存;⑸不能產生事件;⑹不能產生讀進程;⑺不能產生寫進程;

●StopComm方法用於關閉串口,沒有返回值;

●WriteCommData(pDataToWrite: PChar;dwSizeofDataToWrite:Word )方法是個帶有布爾型返回值的函數,用於將一個字元串發送到寫進程,發送成功返回 true,發送失敗返回 false。執行此函數將立即得到返回值,發送操作隨後執行。該函數有兩個參數,其中 pDataToWrite是要發送的字元串, dwSizeofDataToWrite是發送字元串的長度。

3.事件

●OnReceiveData :procere (Sender: TObject;Buffer: Pointer;BufferLength: Word) of object

當有數據輸入緩存時將觸發該事件,在這里可以對從串口收到的數據進行處理。 Buffer中是收到的數據, BufferLength是收到的數據長度。

●OnReceiveError : procere(Sender: TObject; EventMask : DWORD)

當接收數據出現錯誤時將觸發該事件。

SPCOMM的使用

下面是一個利用 SPCOMM控制項的串口通信的例子。

以實現 PC機與單片機 8051之間的通信為例,首先要調通它們之間的握手信號。假定它們之間的通信協議是: PC到 8051一幀數據 6個位元組, 8051到 PC一幀數據也為 6個位元組。當 PC發出( F0,01,FF,FF,01,F0)後 8051能收到一幀( F0,01,FF,FF,01,F0),表示數據通信握手成功,兩者之間就可以按照協議相互傳輸數據。

創建一個新的工程 COMM.DPR,把窗體的 NAME屬性定為 FCOMM,把窗體的標題定義為測試通信,按照圖 2添加控制項 (圖 2中黑色矩形圍住的控制項即為 COMM1)。

圖 2
1.設定 COMM1屬性:

●波特率: 4800;

●奇偶校驗位:無;

●位元組長度: 8;

●停止位: 1;

●串口: COM1。

Memo1中將顯示發送和接收的數據。將新的窗體存儲為 Comm.pas。

2.編寫源代碼

//變數說明

var

fcomm: TFCOMM;

viewstring:string;

i:integer;

rbuf,sbuf:array[16] of byte;

//打開串口

procere TFCOMM.FormShow(Sender: TObject);

begin

comm1.StartComm;

end;

//關閉串口

procere TFCOMM.FormClose(Sender: TObject; var Action: TCloseAction);

begin

comm1.StopComm;

end;

//自定義發送數據過程

procere senddata;

var

i:integer;

commflg:boolean;

begin

viewstring:=『』 ;

commflg:=true;

for i:=1 to 6 do

begin

if not fcomm.comm1.writecommdata(@sbuf[i],1) then

begin

commflg:=false;

break;

end;

//發送時位元組間的延時

sleep(2);

viewstring:=viewstring+ inttohex(sbuf[i],2)+『』 ; end;

viewstring:=『發送』+ viewstring;

fcomm.memo1.lines.add(viewstring);

fcomm.memo1.lines.add(『』 );

if not commflg then messagedlg(『發送失敗 !』 ,mterror,[mbyes],0);

end;

//發送按鈕的點擊事件

procere TFCOMM.Btn_sendClick(Sender: TObject);

begin

sbuf[1]:=byte($ f0); //幀頭

sbuf[2]:=byte($ 01); //命令號

sbuf[3]:=byte($ ff);

sbuf[4]:=byte($ ff);

sbuf[5]:=byte($ 01);

sbuf[6]:=byte($ f0); //幀尾

senddata;//調用發送函數

end;

//接收過程

procere TFCOMM.Comm1ReceiveData(Sender: TObject; Buffer: Pointer;BufferLength: Word);

var

i:integer;

begin

viewstring:=『』 ;

move(buffer^,pchar(@rbuf^),bufferlength);

for i:=1 to bufferlength do

viewstring:=viewstring+ inttohex(rbuf[i],2)+『』 ;

viewstring:=『接收』+ viewstring;

memo1.lines.add(viewstring);

memo1.lines.add(『』 );

end;

② Delphi中如何多線程操作資料庫中的數據表

1。通過線程的互斥來同步操作資料庫 2。資料庫採用事務處理表中的數據 3。採用共享方式打開資料庫,不是以獨占方式打開資料庫 建立一個mysql連接表加上一個臨界區,表結點是這樣的(mysqlcon,bool),根據實際情況定大校我用的是10個連接。

③ delphi 多線程讀寫資料庫

操作資料庫之前對表進行lock,操作完後進行解鎖。
也可以申請一個互斥變數,每次要操作數據之前申請,結束後釋放
前者用的是資料庫自己提供的功能,後者是自己控制操作別同時發生。建議用前者。

④ delphi在線程中建立ado的資料庫連接

很簡單,按如下5步,即可實現線程中連接DB:

1. 通過菜單->File->new->Other,新建一個thread object,線程類不妨命名為TThreadTest,單元名不妨另存為unitThreadTest

2. 在線程自動生成的Execute過程中撰寫資料庫連接代碼

3. 在主窗體中引用線程單元:
use unitThreadTest

4. 在主窗體中定義一個線程變數ThreadTest:TThreadTest;

5. 在主窗體的FormCreate過程中自動創建線程並讓線程立即運行:
ThreadTest:=TThreadTest.Create(false);

閱讀全文

與delphi線程接收串口大資料庫相關的資料

熱點內容
iphone5文稿與數據怎麼刪除 瀏覽:145
java匿名函數參數 瀏覽:215
excel怎麼將csv文件內容分列 瀏覽:550
文件路徑不轉義字元 瀏覽:285
怎樣使用手機鎖屏密碼 瀏覽:802
如何將pdf文件規格縮小 瀏覽:421
魔獸世界70治療升級 瀏覽:103
linuxarm線程數量 瀏覽:880
資料庫的重要性是什麼 瀏覽:881
toolboxjs安裝 瀏覽:85
安卓3g上網卡代碼 瀏覽:306
vuejsjs數據綁定 瀏覽:323
企鵝號視頻app叫什麼 瀏覽:157
indd文件用ps打不開 瀏覽:759
磁碟清理後找不到文件 瀏覽:379
會計學科代碼 瀏覽:507
文件夾選項沒有了xp 瀏覽:167
win7更改文件格式 瀏覽:195
對件內文件排序通常按照什麼順序 瀏覽:12
win10怎樣修復系統文件在哪裡 瀏覽:772

友情鏈接