QTcpSocket

QTcpSocket read write buffer 收藏
QTcpSocket read write buffer

 

write时,系统不保证一次发送完毕,所以应当循环write

假设发送一个QByteArray arr;

int size=socket.write(arr);

while(size < arr.size() )

{

  size += socket.write(  arr.right(arr.size() - size )  );

}

 

 

 

读的时候,直接用socket读,可以用QDataStream读,只是用QDataStream的话,一定要确定当前可读的字节数满足你读的需要

可以参考Qt自带的例子中中,ForntueClient;

1 先判断可读的字节数够不够sizeof(qint32)或者sizeof(qint16), 按照你的协议

2 够的话,就读这个为size,不够的话,返回,等待下次readyRead触发你的slot;或者调用waitForReadReady进行阻塞式的等待

3 判断bytesAvailable够不够size,够则读; 不够则“返回,等待下次readyRead触发你的slot;或者调用waitForReadReady进行阻塞式的等待”

上述返回后,依然保留着size在类中,所以,有个类的设计问题。

 

见到一个新的写发,本质上一样的,似乎有点新意

1.while( true )
2.{
3.    switch( state )
4.    {
5.        case WaitSize:
6.            if( stream.bytesAvailable() < sizeof( dataSize ) ) return;
7.            sretam >> dataSize;
8.            state = WaitData;
9.            break;
10.        case WaitData:
11.            if( stream.bytesAvailable() < dataSize ) return;
12.            // read the data 13.            state = WaitSize;
14.            break;
15.    }
16.}

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/mmmcu2004/archive/2008/12/07/3470419.aspx

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值