QTcpSocket 内存问题「建议收藏」

QTcpSocket 内存问题「建议收藏」我自己测试也发现反复的connectToHost会有内存泄露,建议谨慎的使用!////////////////////////////////////////////////QTcpSocket类的方法connectToHost会泄露内存,即使把调用这个方法的QTcpSocket实例delete掉,内存也不会释放!反复connectToHost会导致段错误,十分危险。必须控制connectToH…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

我自己测试也发现反复的connectToHost会有内存泄露,建议谨慎的使用!


QTcpSocket类的方法connectToHost会泄露内存, 即使把调用这个方法的QTcpSocket实例delete掉,内存也不会释放!反复connectToHost会导致段错误,十分危险。必须控制connectToHost的使用次数!

1. 连接服务器
m_tcpSocket->connectToHost(“127.0.0.1”, 9877);
connected = m_tcpSocket->waitForConnected();
只有使用waitForConnected()后,QTcpSocket才真正尝试连接服务器,并返回是否连接的结果。

2. 写数据
m_tcpSocket->write(str.toStdString().c_str(), strlen(str.toStdString().c_str()));
m_tcpSocket->waitForBytesWritten();
当使用waitForBytesWritten()后,QTcpSocket才真正发送数据。
m_tcpSocket->write(str1.toStdString().c_str(), strlen(str1.toStdString().c_str()));
m_tcpSocket->write(str2.toStdString().c_str(), strlen(str2.toStdString().c_str()));
的结果是发送了str1str2

3. 断开与服务器的连接
m_tcpSocket->disconnectFromHost()
m_tcpSocket->waitForDisconnected()

4. 善于使用QTcpSocket的SIGNAL:connected(), disconnected(), error(QAbstractSocket::SocketError)
 配合自定义私有开关变量bool connected, QTimer
 可以实现自动重连接等逻辑。


其他参见:

[经验分享] QTcpSocket调试经验分享

http://www.thisisqt.com/forum/viewthread.php?tid=460

这久在写一个基于TCP的通信程序,Server端用WinCE实现,而Client端用Qt实现,之前已写了一个VC的Client端,能正确向Server发送数据。

将Client端改用Qt实现后connectToHost()后,server端已能正确accept(),但就是write()后server的read函数无法响应。调试了半天没有成功,火大呀!今天试着输出socket的状态后得到如下:

  1. bool TcpClient::newConnect(const QString &iAddr, quint16 iPort)
  2. {

  3.     mSocket = newQTcpSocket(this);
  4.     mSocket->connectToHost(iAddr,iPort);
  5.     qDebug(“State:%d\n”,mSocket->state());   // State: 2; 2代表ConnectingState,正确的应该为3(ConnectedState)

  6.     connect(mSocket,SIGNAL(readyRead()),this,SLOT(read()));
  7.     connect(mSocket,SIGNAL(disconnected()),this,SLOT(disConnect()));return(true);
  8. }

  9. qint64 TcpClient::write(const QByteArray &iData)
  10. {

  11.     qint64len = mSocket->write(iData);
  12.     qDebug(“State:%d\n”,mSocket->state()); // State: 2; 2代表ConnectingState,正确的应该为3(ConnectedState)

  13.     msleep(200);
  14.     return(len);
  15. }

复制代码

通过输出状态,已经找到问题的所在,哎!都是业务不熟害的呀!
socket的连接是异步的,所以必须等连接建立完成才能使用,所以分别加入waitForConnected()和waitForBytesWritten()后调试通过。

  1. bool TcpClient::newConnect(const QString &iAddr, quint16 iPort)
  2. {

  3.     mSocket = newQTcpSocket(this);
  4.     mSocket->connectToHost(iAddr, iPort);
  5.     qDebug(“State:%d\n”,mSocket->state());   // State: 2; 2代表ConnectingState,正确的应该为3(ConnectedState)

  6.     constintTimeout=5*1000;
  7.     if(!mSocket->waitForConnected(Timeout))
  8.     {

  9.         return(false);
  10.     }
  11.     qDebug(“State:%d\n”,mSocket>state()); // State: 3(ConnectedState)正确

  12.     connect(mSocket,SIGNAL(readyRead()),this,SLOT(read()));
  13.     connect(mSocket,SIGNAL(disconnected()),this,SLOT(disConnect()));return(true);
  14. }

  15. qint64 TcpClient::write(const QByteArray &iData)
  16. {

  17.     qint64len = mSocket->write(iData);
  18.     mSocket->waitForBytesWritten(300);
  19.     qDebug(“State:%d\n”,mSocket->state());  // State: 3(ConnectedState)正确

  20.     msleep(200);
  21.     return(len);
  22. }

QT下用QTcpSocket传输文件, 调用了QTcpSocket:write()但是如何没有bytesWritten信号上来

http://www.myexception.cn/qt/369565.html


[提问]如何正常关闭QTcpsocket?我觉得很难协调好客户端和服务端的关闭操作

有益的讨论:http://www.qtcn.org/bbs/read-htm-tid-26913.html


其它文章:http://www.qtcn.org/bbs/read-htm-tid-56901.html


在构造函数中 new了 一个m_TcpSocket,然后关联了几个信号。

        m_TcpSocket new QTcpSocket(this);
        connect(m_TcpSocket, SIGNAL(readyRead()),this,SLOT(readMessage()));  
    connect(m_TcpSocket, SIGNAL(error(QAbstractSocket::SocketError)),  this,SLOT(displayError(QAbstractSocket::SocketError)));
    connect(m_TcpSocket, SIGNAL(connected()), this, SLOT(onConnect()));
    connect(m_TcpSocket, SIGNAL(disconnected()), this, SLOT(onDisConnect()));

然后在 qpushbutton 连接的槽函数中
         m_TcpSocket->abort();
     m_TcpSocket->connectToHost(StrIP,nPort);

当我关闭tcp连接m_TcpSocket->disconnectFromHost();,然后重新连接时发现内存不断增大。

我想实现的是当服务器连接不上的时候,重新进行连接请求直到连接上为止(断线重连)。
我就定义了timer 重复使用connectToHost函数进行连接直到连上为止。
基本功能我实现了,可是在这重复connectToHost时,内存会不停增大。不管我在connectToHost前添加
        m_TcpSocket->abort();

        m_TcpSocket->close();
    m_TcpSocket->disconnectFromHost();
都没用。有什么办法解决么???


版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/195743.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 原生JS 实现页面元素的拖动 拖拽

    原生JS 实现页面元素的拖动 拖拽原生JS实现页面元素的拖拽1.

    2022年6月22日
    86
  • 无人机超远距离WiFi传输,CV5200无线通信模组,无线音视频传输方案「建议收藏」

    无人机超远距离WiFi传输,CV5200无线通信模组,无线音视频传输方案「建议收藏」在绝大多数任务场合都需要在远离现场的情况下,实时、可靠的观察或获取现场图像及视频,而此时无人机图传系统就会显现出它的重要作用。什么是无人机图传呢?将现场无人机所搭载的摄像机拍摄到的视频以无线方式实时传送到远距离后方的一种无线电子传输产品。因此无人机图传也被称为无人机的“眼睛”。智能cv5200双向无线通信系统,基于802.11无线通信标准,采用自身开发的LR-WiFi(远距离WiFi)私有协议,具备ML,MRC,LDPC,MIMO-OFDM等高级无线技术。具有传输距离远、可组网、抗干扰性强、

    2022年10月3日
    3
  • python写入txt操作

    python写入txt操作第一种file=open(r’C:\Users\Administrator\Desktop\test.txt’,mode=‘a’,encoding=‘utf-8’)file.write(username+’,’+password+’\n’)上面加粗的r表示不使用转义字符(\)的意思,才能够正常使用地址。第二个a是追加,在第二次写入txt文本的时候不会删除原来的写入的内容,而w虽然也是写入,但是会删除原来写入的内容,如果没有文本w还会自动生成文本。file.write(username+’,

    2022年10月2日
    2
  • 你真的懂Java怎么输出Hello World吗?「建议收藏」

    你真的懂Java怎么输出HelloWorld吗?1.你会不会输出”HelloWorld!”?2.小生抛砖引玉,欢迎指正3.总结1.你会不会输出”HelloWorld!”?当我们学习一门编程语言的时候,我们都会先学如何输出HelloWorld!????:“你真的会吗?”????:“会!”????:“以下这几个例子,我背都给你背下来!!!!”【骄傲】C语言printf(“HelloWorld!”);C++语言cout<<“HelloWorld!”;

    2022年4月15日
    92
  • android开发之滑动效果实现图片浏览_ViewFilpper的使用

    ViewFilpper 是Android官方提供的一个View容器类,继承于ViewAnimator类,用于实现页面切换,也可以设定时间间隔,让它自动播放。又ViewAnimator继承至于FrameLayout的,所以ViewFilpper的Layout里面可以放置多个View 本示例通过ViewFlipper和GestureDetector.OnGestureListener实现自

    2022年3月10日
    43
  • 卸载Symantec Endpoint Protection, 无需password的卸载方法

    卸载Symantec Endpoint Protection, 无需password的卸载方法

    2021年12月10日
    92

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号