读串口的代码在网上是铺天盖地,但他们几乎完全是一样的,第一个人写出来的才是英雄,其它的不是。这段代码类似于下面:
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类,大家知道,类要构造与析构,我敢保证,我上面的程序,在效率上,在第一段代码构造类的时候,我的代码已经收完数据了。另一点,是次要的,但要提一下,看看两段程序申请的变量个数,程序的长度,可读性,我的代码都应该较好! 
|