读串口的代码在网上是铺天盖地,但他们几乎完全是一样的,第一个人写出来的才是英雄,其它的不是。这段代码类似于下面:
VARIANT variant_inp;
COleSafeArray safearray_inp;
LONG len,k;
BYTE rxdata[2048]; //设置BYTE数组 An 8-bit integerthat is not signed.
CString strtemp;
if(m_ctrlComm.GetCommEvent()==2) //事件值为2表示接收缓冲区内有字符
{
////////以下你可以根据自己的通信协议加入处理代码
variant_inp=m_ctrlComm.GetInput(); //读缓冲区
safearray_inp=variant_inp; //VARIANT型变量转换为ColeSafeArray型变量
len=safearray_inp.GetOneDimSize(); //得到有效数据长度
for(k=0;k<len;k++)
safearray_inp.GetElement(&k,rxdata+k);//转换为BYTE型数组
for(k=0;k<len;k++) //将数组转换为Cstring型变量
{
BYTE bt=*(char*)(rxdata+k); //字符型
strtemp.Format("%c",bt); //将字符送入临时变量strtemp存放
m_strRXData+=strtemp; //加入接收编辑框对应字符串
}
}
UpdateData(FALSE); //更新编辑框内容
下面我先给出我的代码:
VARIANT Rec_Data;
int Data_Len;
char Rec_Data_Array[2048];
if (m_ctrlComm.GetCommEvent() == 2) //事件值为2表示接收缓冲区内有字符
{
Rec_Data = m_SerialCOM.GetInput();
int Data_Len = Rec_Data.parray->rgsabound->cElements; //取出一维的数据个数
memcpy(Rec_Data_Array, (char*) Rec_Data.parray->pvData, Data_Len); //拷贝出数据
Rec_Data_Array[Data_Len] = 0;
}
UpdateData(FALSE); //更新编辑框内容
我的代码有以下特点:
一:程序简单;
二:也是最主要的,效率很高!
我没有使用COleSafeArray类,大家知道,类要构造与析构,我敢保证,我上面的程序,在效率上,在第一段代码构造类的时候,我的代码已经收完数据了。另一点,是次要的,但要提一下,看看两段程序申请的变量个数,程序的长度,可读性,我的代码都应该较好!