Qt ------- QByteArray操作注意

使用QByteArray方法把数据存入QByteArray需要是char型数据,如果需要存入无符号8位数据,如下:

QByteArray data;

data[0] = 0xFF;

即使通过data[0] = 0xFF;把无符号数存入QByteArray,在QByteArray也是一char型存放,所以如果需要把存入的无符号数正确的读取出来,如下:

uchar tmp;

tmp = (uchar)data[0];

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果您希望使用QTcpServer实现单线程的服务器端,即一个客户端连接处理完成后再处理下一个客户端连接,可以在incomingConnection()函数中直接处理客户端的连接请求和通信。 下面是一个示例代码,演示了如何使用QTcpServer创建一个单线程的TCP服务器: ```cpp #include <QtNetwork> class MyTcpServer : public QTcpServer { Q_OBJECT public: MyTcpServer(QObject *parent = nullptr) : QTcpServer(parent) { // 在构造函数中监听指定端口 listen(QHostAddress::Any, 1234); } protected: void incomingConnection(qintptr socketDescriptor) override { // 有新连接时执行的操作 QTcpSocket *clientSocket = new QTcpSocket(this); clientSocket->setSocketDescriptor(socketDescriptor); // 处理客户端请求和通信 while (clientSocket->state() == QAbstractSocket::ConnectedState) { if (clientSocket->waitForReadyRead()) { QByteArray data = clientSocket->readAll(); // 处理客户端发送的数据... // 回复客户端... } } // 客户端断开连接后清理资源 clientSocket->deleteLater(); } }; int main(int argc, char *argv[]) { QCoreApplication a(argc, argv); MyTcpServer server; if (!server.listen(QHostAddress::Any, 1234)) { qCritical() << "Failed to start server!"; return 1; } qDebug() << "Server started."; return a.exec(); } ``` 在这个示例中,incomingConnection()函数内部使用了一个while循环来处理客户端的连接请求和通信。每当有客户端连接成功并发送数据时,我们会读取数据并进行处理,然后继续等待下一个客户端发送数据。当客户端断开连接时,我们会通过deleteLater()函数来释放资源。 请注意,这个示例是一个简化的实现,没有考虑到错误处理和并发连接的情况。如果您需要更复杂的功能,例如处理多个并发连接或错误处理,请考虑使用多线程或使用Qt的其他网络类来实现。 希望对您有所帮助!如果您有任何其他问题,请随时提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值