J'ai joué avec la bibliothèque XML Xerces-C.Problèmes Xerces-C; segfault sur appel à un destructeur d'objet
J'ai cet exemple simple avec lequel je joue.
Je n'arrive pas à l'exécuter sans fuites de mémoire et sans segfault. C'est l'un ou l'autre.
La segfault se produit toujours lorsque je supprime l'objet analyseur sous "Nettoyage".
J'ai essayé d'utiliser à la fois les versions 2.8 & 2.7 de la bibliothèque.
Remarque: J'ai pris toutes les vérifications d'exception du code, j'obtiens le même résultat avec et sans. Pour plus de lisibilité et de simplicité, je l'ai retiré du code ci-dessous.
Est-ce que les gens avertis de Xerces sont là pour vous faire des suggestions?
Je ne peux pas vraiment dire grand-chose de la trace arrière, c'est juste de sauter dans le destructeur de la super-classe et segfaulting là.
Backtrace:
(gdb) bt
#0 0x9618ae42 in __kill()
#1 0x9618ae34 in kill$UNIX2003()
#2 0x961fd23a in raise()
#3 0x96209679 in abort()
#4 0x95c5c005 in __gnu_cxx::__verbose_terminate_handler()
#5 0x95c5a10c in __gxx_personality_v0()
#6 0x95c5a14b in std::terminate()
#7 0x95c5a6da in __cxa_pure_virtual()
#8 0x003e923e in xercesc_2_8::AbstractDOMParser::cleanUp()
#9 0x003ead2a in xercesc_2_8::AbstractDOMParser::~AbstractDOMParser()
#10 0x0057022d in xercesc_2_8::XercesDOMParser::~XercesDOMParser()
#11 0x000026c9 in main (argc=2, argv=0xbffff460) at test.C:77
Le code:
#include <string>
#include <vector>
#if defined(XERCES_NEW_IOSTREAMS)
#include <iostream>
#else
#include <iostream.h>
#endif
#include <xercesc/dom/DOM.hpp>
#include <xercesc/dom/DOMDocument.hpp>
#include <xercesc/dom/DOMElement.hpp>
#include <xercesc/dom/DOMImplementation.hpp>
#include <xercesc/parsers/XercesDOMParser.hpp>
#include <xercesc/util/XMLString.hpp>
#include <xercesc/util/PlatformUtils.hpp>
#include <xercesc/sax/HandlerBase.hpp>
#include <xercesc/util/OutOfMemoryException.hpp>
#include <xercesc/framework/MemBufInputSource.hpp>
using namespace std;
XERCES_CPP_NAMESPACE_USE
int main(int argc, char const* argv[])
{
string skXmlMetadata = "<?xml version=\"1.0\"?>\n <xmlMetadata>b</xmlMetadata>";
XMLPlatformUtils::Initialize();
XercesDOMParser* xmlParser = NULL;
DOMWriter* xmlWriter = NULL;
ErrorHandler* errHandler = NULL;
const XMLByte* xmlBuf = NULL;
MemBufInputSource* memBufIS = NULL;
DOMNode* xmlDoc = NULL;
xmlParser = new XercesDOMParser();
xmlParser->setValidationScheme(XercesDOMParser::Val_Never);
xmlParser->setDoNamespaces(false);
xmlParser->setDoSchema(false);
xmlParser->setLoadExternalDTD(false);
errHandler = (ErrorHandler*) new HandlerBase();
xmlParser->setErrorHandler(errHandler);
// Create buffer for current xmlMetadata
xmlBuf = (const XMLByte*) skXmlMetadata.c_str();
const char* bufID = "XmlMetadata";
memBufIS = new MemBufInputSource(xmlBuf, skXmlMetadata.length(), bufID, false);
// Parse
xmlParser->resetErrors();
xmlParser->parse(*memBufIS);
xmlDoc = xmlParser->getDocument();
// Write created xml to input SkArray
XMLCh* metadata = NULL;
xmlWriter = DOMImplementation::getImplementation()->createDOMWriter();
xmlWriter->setFeature(XMLUni::fgDOMWRTFormatPrettyPrint, true);
metadata = xmlWriter->writeToString(*xmlDoc);
xmlWriter->release();
// Print out our parsed document
char* xmlMetadata = XMLString::transcode(metadata);
string c = xmlMetadata;
cout << c << endl;
// Clean up
XMLString::release(&xmlMetadata);
xmlDoc->release();
delete xmlParser; // Dies here
delete memBufIS;
delete errHandler;
XMLPlatformUtils::Terminate();
return 0;
}
Il peut aider les gens à zéro sur votre problème si vous pouvez pointer sur la ligne 77 qui est dans votre source. Peut-être un commentaire de fin de ligne comme "// meurt ici"? –
Donc, je ne connais pas Xerces, mais avez-vous essayé d'utiliser RAII avec un fichier std :: auto_ptr ou similaire? Si vous voulez éviter cela, je supprime généralement les éléments dans l'ordre inverse, je les nouveaux. Il peut y avoir une interaction étrange entre le xmlParser et le gestionnaire d'erreurs, car vous supprimez le xmlParser avant errorHandler? – jdt141
Les analyseurs Xerces ne possèdent pas leurs gestionnaires d'erreurs, c'est donc l'ordre correct. –