案例:
假如发送间隔发送一个字符串,间隔时间、长度不确定,没有起始、结束的标志;可以确定是发送端一口气发送完后字符串,并且能够假定有最大长度,如何处理;
cnComm 1.3可以一定程度的解决这个问题;
假设字符串的最大长度为20,设定每次读为3倍的最大长度即60;不能确定的就尽可能大一点;
比如发送端发送“012345678987654321 ",
对于原有版本来说可能被分割成
“0123”
"4567"
........
采用该方案
那个一次接受的数据可能是
“012345678987654321 "
或者
“012345678987654321012345678987654321 "
即一次接受1-2个完整的数据包;
应该能够满足这部分网友的需要,但是全部只接受一个完整的,目前我没有完美的方案;
你可以在分析一下,是一个数据包还是2个;
以上方案缺点是速度慢,但是在线程也无法所谓速度
对于不会分割中文的朋友,可以使用,这样应该不会出现中文字符被分割的情况
假如发送间隔发送一个字符串,间隔时间、长度不确定,没有起始、结束的标志;可以确定是发送端一口气发送完后字符串,并且能够假定有最大长度,如何处理;
cnComm 1.3可以一定程度的解决这个问题;
假设字符串的最大长度为20,设定每次读为3倍的最大长度即60;不能确定的就尽可能大一点;
class
MyCom :
public
CxComm
{
virtual void OnReceive()
{
char buf[ 128 ];
int len = Read(buf, 60 , false );
buf[len] = 0 ;
if (len > 0 )
cout << buf << endl;
}
};
{
virtual void OnReceive()
{
char buf[ 128 ];
int len = Read(buf, 60 , false );
buf[len] = 0 ;
if (len > 0 )
cout << buf << endl;
}
};
比如发送端发送“012345678987654321 ",
对于原有版本来说可能被分割成
“0123”
"4567"
........
采用该方案
那个一次接受的数据可能是
“012345678987654321 "
或者
“012345678987654321012345678987654321 "
即一次接受1-2个完整的数据包;
应该能够满足这部分网友的需要,但是全部只接受一个完整的,目前我没有完美的方案;
你可以在分析一下,是一个数据包还是2个;
以上方案缺点是速度慢,但是在线程也无法所谓速度
对于不会分割中文的朋友,可以使用,这样应该不会出现中文字符被分割的情况