串口代码优化求解
void CCOMMDlg::OnOnCommMscomm1()
{
// TODO: Add your control notification handler code here
VARIANT variant_inp;
COleSafeArray safearray_inp;
LONG len,k;
BYTE rxdata[2048]; //设置BYTE数组 An 8-bit integerthat is not signed.
CString strtemp;
if(m_Comm.GetCommEvent()==2) //事件值为2表示接收缓冲区内有字符
{ ////////以下你可以根据自己的通信协议加入处理代码
variant_inp=m_Comm.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_RDDate+=strtemp; //加入接收编辑框对应字符串
}
}
UpdateData(FALSE); //更新编辑框内容
}
这是初学vc串口时搞来的一段数据接受代码
对其中有段代码非常不解,虽然这个串口程序非常经典
但是始终觉得其中比较冗余,做了些无用功
for(k=0;k<len;k++) //将数组转换为Cstring型变量
{
BYTE bt=*(char*)(rxdata+k); // 强制将BYTE型数组转化层字符型并将数组中的一个字符赋值给bt
strtemp.Format("%c",bt); //将字符送入临时变量strtemp存放
m_RDDate+=strtemp; //加入接收编辑框对应字符串
}
这其中有必要使用(char*)这个强制转化吗?我将之删除后程序也能正常运行啊
不知直接将rxdata数组里的数一个个调用出来通过strtemp.Format("%c",bt)完成转化,就完事了了吗?
小弟学疏才浅,又是刚刚入门。看到的总是很短浅。对于权威性的代码不敢妄下定论,所以拿出来讨论讨论
[解决办法]
void CCOMMDlg::OnOnCommMscomm1() { VARIANT variant_inp; COleSafeArray safearray_inp; LONG len,k; BYTE rxdata[2048]; //设置BYTE数组 An 8-bit integerthat is not signed. CString strtemp; if(m_Comm.GetCommEvent()==2) //事件值为2表示接收缓冲区内有字符 { ////////以下你可以根据自己的通信协议加入处理代码 variant_inp=m_Comm.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_RDDate+=strtemp; //加入接收编辑框对应字符串 } } UpdateData(FALSE); //更新编辑框内容 }