IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)

Qt Serialization

Serializations provided by Qt API.

Article lu   fois.

L'auteur

Liens sociaux

Viadeo Twitter Facebook Share on Google+   

Qt Serialization

The purpose of serialization is to save the state of an object to be able to recreate it when needed. It allows you to perform actions like:

  • Sending the object to a remote application by using a web service

  • Passing the object as a JSON or XML string

  • Saving and restoring user information or sharing it across applications

The Qt API provides support for serialization for several use cases:

  • JSON support in Qt provides an easy to use C++ API to parse, modify and save JSON data. CBOR Support in Qt is a compact form of binary data encoding that is a superset of JSON.

  • QDataStream provides serialization of binary data to a QIODevice

  • Qt XML C++ Classes provide C++ implementations of the XML Streaming and DOM standards for XML

  • CBOR is Qt's implementation for the CBOR serialization format.

  • QSettings provides a way of serializing and storing platform independent application settings.

Advantages of JSON and CBOR

When you use JSON information is stored in a QJsonObject and a QJsonDocument takes care to stream values into a QByteArray.

For example

 
Sélectionnez
QJsonObject jobject;
jobject["SensorID"] = m_id;
jobject["AmbientTemperature"] = m_ambientTemperature;
jobject["ObjectTemperature"] = m_objectTemperature;
jobject["AccelerometerX"] = m_accelerometerX;
jobject["AccelerometerY"] = m_accelerometerY;
jobject["AccelerometerZ"] = m_accelerometerZ;
jobject["Altitude"] = m_altitude;
jobject["Light"] = m_light;
jobject["Humidity"] = m_humidity;
QJsonDocument doc( jobject );

return doc.toJson();

JSON has several advantages:

  • Textual JSON is declarative, which makes it readable to humans

  • The information is structured

  • Exchanging generic information is easy

  • JSON allows extending messages with additional values

  • Many solutions exist to receive and parse JSON in cloud-based solutions

CBOR is the Concise Binary Object Representation, a very compact form of binary data encoding that is a superset of JSON. It was created by the IETF Constrained RESTful Environments (CoRE) WG, which has been used in many new RFCs. CBOR shares many of the advantages of JSON, but sacrifices human readability for compactness.

Advantages of QDataStream Classes

QDataStream is a viable option when the whole flow of data is determined and not about to change. In addition, both the reader and the writer of the data must be written in Qt.

Adding support for this to a class requires two additional operators. For example, for a class named SensorInformation:

 
Sélectionnez
QDataStream &operator<<(QDataStream &, const SensorInformation &);
QDataStream &operator>>(QDataStream &, SensorInformation &);

The implementation for the serialization is shown below:

 
Sélectionnez
QDataStream &operator<<(QDataStream &out, const SensorInformation &item)
{
    QDataStream::FloatingPointPrecision prev = out.floatingPointPrecision();
    out.setFloatingPointPrecision(QDataStream::DoublePrecision);
    out << item.m_id
        << item.m_ambientTemperature
        << item.m_objectTemperature
        << item.m_accelerometerX
        << item.m_accelerometerY
        << item.m_accelerometerZ
        << item.m_altitude
        << item.m_light
        << item.m_humidity;
    out.setFloatingPointPrecision(prev);
    return out;
}

Deserialization works similarly, but using the >> operator. For example, out >> item.m_id, and so on.

Usually, using QDataStream is faster than using textual JSON.

Advantages of Qt XML C++ Classes

Qt provides the QDomDocument class that represents the XML document and two classes for reading and writing the XML through a simple streaming API: QXmlStreamReader and QXmlStreamWriter.

QDomDocument class represents the entire XML document. It is the root of the document tree and provides primary access to the document's data.

A stream reader reports an XML document as a stream of tokens. This differs from SAX as SAX applications provide handlers to receive XML events from the parser, whereas the QXmlStreamReader drives the loop, pulling tokens from the reader when they are needed. This pulling approach makes it possible to build recursive descent parsers, allowing XML parsing code to be split into different methods or classes.

QXmlStreamReader a parser for well-formed XML 1.0, excluding external parsed entities. Hence, data provided to the stream reader adheres to the W3C's criteria for well-formed XML, or an error will be raised. Functions such as atEnd(), error(), and hasError() can be used to test for such errors and obtain a description of them.

The QXmlStreamWriter is a streaming API that takes care of prefixing namespaces, when the namespaceUri is specified when writing elements or attributes.

Classes that provide serialization

  • <QtCborCommon>: The <QtCborCommon> header contains definitions common to both the streaming classes (QCborStreamReader and QCborStreamWriter) and to QCborValue.

  • QCborArray: The QCborArray class is used to hold an array of CBOR elements.

  • QCborMap: The QCborMap class is used to hold an associative container representable in CBOR.

  • QCborStreamReader: The QCborStreamReader class is a simple CBOR stream decoder, operating on either a QByteArray or QIODevice.

  • QCborStreamWriter: The QCborStreamWriter class is a simple CBOR encoder operating on a one-way stream.

  • QCborValue: The QCborValue class encapsulates a value in CBOR.

  • QDataStream: The QDataStream class provides serialization of binary data to a QIODevice.

  • QJsonArray: The QJsonArray class encapsulates a JSON array.

  • QJsonDocument: The QJsonDocument class provides a way to read and write JSON documents.

  • QJsonObject: The QJsonObject class encapsulates a JSON object.

  • QJsonParseError: The QJsonParseError class is used to report errors during JSON parsing.

  • QJsonValue: The QJsonValue class encapsulates a value in JSON.

  • QTextStream: The QTextStream class provides a convenient interface for reading and writing text.

  • QXmlStreamReader: The QXmlStreamReader class provides a fast parser for reading well-formed XML via a simple streaming API.

  • QXmlStreamWriter: The QXmlStreamWriter class provides an XML writer with a simple streaming API.

Vous avez aimé ce tutoriel ? Alors partagez-le en cliquant sur les boutons suivants : Viadeo Twitter Facebook Share on Google+