项目负责利用TCP来传输一组大的数据,然后在接收函数里将接收的数组进行解包赋值。
从结果来看发现解包出来的数据都是错误的,几乎都是随机并且好几个值是负无穷。
这里就发现了QT的TCP传输机制,它将我的数据分两次接收,每一次是原来的一半。
例如我传3000字节大小,那么它会拆成两次1500,偶尔会出现2966和44或者一次满包的情况。
随着你传输数据越大,能一次性满包的概率越小。
我在项目里用的是readAll函数,并没有找到QT函数中能阻塞式接收指定数据大小的函数。
当然了数据过大会分包,数据过小的频繁传输会粘包。
又或者因为两次传输的时间分隔比较小,所以导致redyread只触发一次的问题都有可能遇到。
关于上述分包的解决办法是因为我知道数据包一次传输的大小。
所以再readAll后立即判断buff. size()的大小是否大于一次传输的大小 即>=3000
不是的话吧buff赋值给全局变量 第二次出发radyread信号 再通过append来拼接两个或者三个包。