Es ist lange her, dass Artikel das Parsen von XML-Dokumenten mit Qt berührt haben. Ich möchte Ihnen einige Neuigkeiten über die erwarteten Änderungen in den nächsten Versionen mitteilen. Aber lassen Sie uns zunächst zusammenfassen, was Qt derzeit zum Lesen und Schreiben von XML-Dokumenten bereitstellt.
Qt XML-Modul
Dieses Modul bietet Implementierungen für zwei verschiedene Modelle zum Lesen und Schreiben von XML-Dateien: das Document Object Model DOM und die Simple XML API (SAX). Im DOM wird die vollständige XML-Datei in den Speicher geladen und als Baum dargestellt, was den Zugriff und die Bearbeitung ihrer Knoten erleichtert. DOM wird im Allgemeinen in Anwendungen verwendet, in denen Sie sich nicht um den Speicher kümmern. SAX hingegen ist ein ereignisbasierter XML-Parser und lädt nicht das gesamte XML-Dokument in den Speicher. Stattdessen generiert es während der Analyse Ereignisse für Token, und der Benutzer kann diese Ereignisse behandeln. Die Anwendung muss die Handler-Schnittstellen implementieren (ganz oder teilweise mit QXmlDefaultHandler). Viele Leute finden das unbequem, da es sie dazu zwingt, ihren Code um dieses Modell herum zu strukturieren.
Ein weiteres Problem besteht darin, dass die aktuelle Implementierung von SAX (und damit auch DOM, da es mit SAX implementiert ist) nicht vollständig mit dem XML-Standard kompatibel ist. Angesichts dieser Mängel empfiehlt Qt die Verwendung von SAX nicht mehr, und es wurde die Entscheidung getroffen, diese Klassen ab Qt 5.15 abzulehnen.
QXmlStreamReader und QXmlStreamWriter
Glücklicherweise bietet Qt XML-Streaming-Klassen als bequemere und XML-kompatible Alternative für die Arbeit mit XML-Dateien.
Was wird sich in Qt 6 ändern?
Wie oben erwähnt, werden SAX-Klassen bald veraltet sein, was bedeutet, dass QDomDocument sie nicht mehr verwenden kann. Deshalb wurde es mit QXmlStreamReader neu implementiert. Qt 6 wird auf die neue Implementierung umstellen, aber ältere Versionen von Qt werden weiterhin die alte Implementierung verwenden, da die neue einige Verhaltensänderungen mit sich bringen wird und die Entwickler dies erst mit Qt 6 tun wollen.
Was bedeutet diese Änderung für Qt-DOM-Benutzer? Da QXmlStreamReader der XML-Spezifikation genauer folgt, wird QDomDocument ab Qt 6 dasselbe tun. Dies bedeutet die folgenden Verhaltensänderungen für QDomDocument:
•
Attributwerte werden normalisiert
. Zum Beispiel,
•
Identische qualifizierte Attributnamen sind nicht mehr erlaubt
, dh Elementattribute müssen eindeutige Namen haben.
•
nicht deklarierte Namespace-Präfixe werden nicht länger erlaubt
.
Wenn Sie QDomDocument verwenden und sich auf eines davon verlassen, sollten Sie erwägen, Ihren Code und Ihre XML-Dokumente entsprechend zu aktualisieren.