QT Qudpsocket 調試卡死

QT Qudpsocket 調試卡死:
以爲是還沒有connected成功就write to socket的問題,
經過調試之後發現,原來問題出現於hasPendingDatagrams。
原來的代碼是:
while (udsocket->hasPendingDatagrams())
{
newTime.resize(udsocket->pendingDatagramSize());
udsocket->read(newTime.data(), newTime.size());
};

發現當然使用udp的時候, 沒有connected(), readready()的説法, 反正一旦connectedtoHost之後,這兩個事件都是是會自己出來的, 不像tcp。

當沒有數據回來到socket的時候,while循環就一直在跑,導致卡死。

解決方法是修改代碼如下:
while (udsocket->hasPendingDatagrams())
{
if(udsocket->pendingDatagramSize()<=0)
return;
newTime.resize(udsocket->pendingDatagramSize());
udsocket->read(newTime.data(), newTime.size());
};

pendingDatagramSize()當pending的datagrams的size是小於等於0, 就不等了。
經過調試, 成功!

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
该错误可能是因为您在调用 `QUdpSocket::hasPendingDatagrams()` 函数时,`QUdpSocket` 对象处于未绑定状态。这可能是因为您在第一次调用 `QUdpSocket::bind()` 函数时绑定失败,但在第二次调用时绑定成功了。 为了解决这个问题,您可以在调用 `QUdpSocket::hasPendingDatagrams()` 之前,先检查 `QUdpSocket` 对象是否处于绑定状态,如果不是,则等待一段时间并重新尝试绑定。以下是一个示例代码片段,展示了如何正确地使用 `QUdpSocket` 对象: ```cpp QUdpSocket udpSocket; bool isBound = false; while (!isBound) { if (udpSocket.bind(QHostAddress::AnyIPv4, 1234)) { isBound = true; } else { qDebug() << "Failed to bind UDP socket to port 1234. Retrying in 1 second..."; QThread::sleep(1); } } while (true) { if (udpSocket.state() == QUdpSocket::BoundState && udpSocket.hasPendingDatagrams()) { QByteArray datagram; datagram.resize(udpSocket.pendingDatagramSize()); udpSocket.readDatagram(datagram.data(), datagram.size()); qDebug() << "Received datagram: " << datagram; } } ``` 在上面的代码中,我们在一个循环中不断尝试将 `QUdpSocket` 对象绑定到本地地址和端口上。如果绑定成功,则将 `isBound` 标记为 `true` 并退出循环。如果绑定失败,则在控制台输出一条错误消息,并等待一秒钟后重试。 在接下来的循环中,我们首先检查 `QUdpSocket` 对象是否处于绑定状态。如果是,则检查是否有待处理的数据报,并在控制台上输出数据报的内容。这样就可以避免在未绑定时调用 `QUdpSocket::hasPendingDatagrams()` 函数而导致的错误。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值