I have a client-server application setup using QTcpServer and QTcpSockets and seem to have some huge memory leaks. I'm wondering if the problem is in my use of Qt's sockets because I have just set up a simple test application and after sending 250,000,000 messages in a loop my client rises up to 75 meg. It seems that if I have several million messages, I see 300+ MB of memory used in my client.
This doesn't seem right to me, as I keep sending messages the memory just keeps on rising!
So should I expect my app to constantly rise in memory given the following code on a connected socket. If this socket is left open I'm going to quickly run out of memory. Am I missing something?
if (socket && socket->isOpen())
{
for(int i = 0; i < 25000000; ++i) {
QString str = "test";
socket->write(str.toStdString().c_str());
}
}
The socket is an internally buffered
QIODevice
, and whatever you've written to it gets buffered until the network stack can actually send it out. What you see is expected behavior. Thewrite()
is not a blocking operation, and anyway you should never ever do blocking operations in your GUI thread, unless you think users really enjoy applications with dead user interface.Perhaps you want to put your writing in a slot that gets informed of the socket's progress? The sockets are all
QIODevice
. Look there for the useful signals,bytesWritten()
for example. It's customary to defer writing unless the value returned bybytesToWrite()
is below a set threshold. Your writing slot could begin like so:Nitpick: The
toStdString()
is completely grauituous. You should be using:Never mind that for such testing, you can trivially create an array of bytes without using a string at all:
This is expected because you are potentially buffering a large amount of data. This is an async API due to the Qt event loop, so you should wait for the write when the program is ready for that.
You can use the
void QIODevice::bytesWritten(qint64 bytes) [signal]
signal to continue the writing. If you use the async API this way, you will avoid the large memory consumption.