QDebug Class | Qt 4.8 (original) (raw)

Detailed Description

The QDebug class provides an output stream for debugging information.

QDebug is used whenever the developer needs to write out debugging or tracing information to a device, file, string or console.

Basic Use

In the common case, it is useful to call the qDebug() function to obtain a default QDebug object to use for writing debugging information.

This constructs a QDebug object using the constructor that accepts a QtMsgType value of QtDebugMsg. Similarly, the qWarning(), qCritical() and qFatal() functions also return QDebug objects for the corresponding message types.

The class also provides several constructors for other situations, including a constructor that accepts a QFile or any other QIODevice subclass that is used to write debugging information to files and other devices. The constructor that accepts a QString is used to write to a string for display or serialization.

Writing Custom Types to a Stream

Many standard types can be written to QDebug objects, and Qt provides support for most Qt value types. To add support for custom types, you need to implement a streaming operator, as in the following example:

QDebug operator<<(QDebug dbg, const Coordinate &c) { dbg.nospace() << "(" << c.x() << ", " << c.y() << ")";

return dbg.space();

}

This is described in the Debugging Techniques and Creating Custom Qt Types documents.

Member Function Documentation

QDebug::QDebug(QIODevice * device)

Constructs a debug stream that writes to the given device.

QDebug::QDebug(QString * string)

Constructs a debug stream that writes to the given string.

QDebug::QDebug(QtMsgType type)

Constructs a debug stream that writes to the handler for the message type specified by type.

QDebug::QDebug(const QDebug & other)

Constructs a copy of the other debug stream.

QDebug::~QDebug()

Flushes any pending data to be written and destroys the debug stream.

QDebug & QDebug::maybeSpace()

Writes a space character to the debug stream, depending on the last character sent to the stream, and returns a reference to the stream.

If the last character was a space character, this function writes a space character to the stream; otherwise, no characters are written to the stream.

See also space() and nospace().

QDebug & QDebug::nospace()

Clears the stream's internal flag that records whether the last character was a space and returns a reference to the stream.

See also space() and maybeSpace().

QDebug & QDebug::space()

Writes a space character to the debug stream and returns a reference to the stream.

The stream will record that the last character sent to the stream was a space.

See also nospace() and maybeSpace().

QDebug & QDebug::operator<<(QChar t)

Writes the character, t, to the stream and returns a reference to the stream.

QDebug & QDebug::operator<<(bool t)

Writes the boolean value, t, to the stream and returns a reference to the stream.

QDebug & QDebug::operator<<(char t)

Writes the character, t, to the stream and returns a reference to the stream.

QDebug & QDebug::operator<<(signed short i)

Writes the signed short integer, i, to the stream and returns a reference to the stream.

QDebug & QDebug::operator<<(unsigned short i)

Writes then unsigned short integer, i, to the stream and returns a reference to the stream.

QDebug & QDebug::operator<<(signed int i)

Writes the signed integer, i, to the stream and returns a reference to the stream.

QDebug & QDebug::operator<<(unsigned int i)

Writes then unsigned integer, i, to the stream and returns a reference to the stream.

QDebug & QDebug::operator<<(signed long l)

Writes the signed long integer, l, to the stream and returns a reference to the stream.

QDebug & QDebug::operator<<(unsigned long l)

Writes then unsigned long integer, l, to the stream and returns a reference to the stream.

QDebug & QDebug::operator<<(qint64 i)

Writes the signed 64-bit integer, i, to the stream and returns a reference to the stream.

QDebug & QDebug::operator<<(quint64 i)

Writes then unsigned 64-bit integer, i, to the stream and returns a reference to the stream.

QDebug & QDebug::operator<<(float f)

Writes the 32-bit floating point number, f, to the stream and returns a reference to the stream.

QDebug & QDebug::operator<<(double f)

Writes the 64-bit floating point number, f, to the stream and returns a reference to the stream.

QDebug & QDebug::operator<<(const char * s)

Writes the '\0'-terminated string, s, to the stream and returns a reference to the stream.

QDebug & QDebug::operator<<(const QString & s)

Writes the string, s, to the stream and returns a reference to the stream.

QDebug & QDebug::operator<<(const QStringRef & s)

Writes the string reference, s, to the stream and returns a reference to the stream.

QDebug & QDebug::operator<<(const QLatin1String & s)

Writes the Latin1-encoded string, s, to the stream and returns a reference to the stream.

QDebug & QDebug::operator<<(const QByteArray & b)

Writes the byte array, b, to the stream and returns a reference to the stream.

QDebug & QDebug::operator<<(const void * p)

Writes a pointer, p, to the stream and returns a reference to the stream.

QDebug & QDebug::operator=(const QDebug & other)

Assigns the other debug stream to this stream and returns a reference to this stream.