使用Xerces C ++我从下面的模式生成了典型的C ++代码。在序列化对象后,我获得了访问冲突。我在堆栈中逐步执行代码,直到std :: basic_string的一些模板化插入代码,它似乎正在那里发生。
我可以在生成的代码中进入问题发生的位置。但这似乎有点矫枉过正。我确定这是我的代码的问题。
我的代码如下。
#include <sstream>
#include <iostream>
#include "..\XMLObjects\SomeXML.hxx"
void serializeObject(Object* mess, std::string& result);
void create();
int _tmain(int argc, _TCHAR* argv[])
{
create();
return 0;
}
void create()
{
std::string result;
objectType oType("Status");
std::auto_ptr<Object> obj( &Object(oType) );
time_t seconds=time(NULL);
Object::status_type s(seconds);
obj->status().set(s);
obj->status()->timeOfUpdate();
serializeObject(obj.get(), result);
}
void serializeObject(Object* mess, std::string& result)
{
std::ostringstream buff;
xml_schema::namespace_infomap nsm;
nsm[""].name = "";
nsm[""].schema = "SomeXML.xsd";
try
{
Object_(buff, *mess, nsm, "UTF-8", xml_schema::flags::no_xml_declaration);
}
catch (const xml_schema::exception& e)
{
std::cout << e << std::endl;
return;
}
catch(std::exception& ex)
{
std::string info(" Caught the exception ");
info+=ex.what();
}
catch(...)
{
std::string info(" Caught an exception ");
}
result=buff.str().c_str();
}
以下是我用来生成代码的架构。
<?xml version="1.0" encoding="utf-8"?>
<!--<schema xmlns="http://www.w3.org/2001/XMLSchema"
targetNamespace="http://www.example.com/SomeXML">-->
<xsd:complexType name ="Status" >
<xsd:sequence>
<xsd:element name="timeOfUpdate" type="xsd:unsignedLong" minOccurs="1" maxOccurs="1"/>
</xsd:sequence>
</xsd:complexType>
<xsd:simpleType name="objectType">
<xsd:restriction base="xsd:string">
<xsd:enumeration value="Status"/>
<xsd:enumeration value="Thing A"/>
<xsd:enumeration value="Thing B"/>
</xsd:restriction>
</xsd:simpleType>
<xsd:complexType name="Object" >
<xsd:sequence>
<xsd:element name="objectType" type ="objectType" minOccurs="1" maxOccurs="1" />
<xsd:element name ="status" type ="Status" minOccurs="0" maxOccurs="1"/>
</xsd:sequence>
</xsd:complexType >
<xsd:element name="Object" type="Object" />
</xsd:schema>
答案 0 :(得分:2)
std::auto_ptr<Object> obj( &Object(oType) );
这很可能是头痛的一个原因。这看起来像你正在创建一个临时的,然后获取它的地址,并将其存储在auto_ptr中。
临时然后立即超出范围,你留下了一个悬空指针。此外,当它到达范围的末尾时,它将尝试delete
最初在堆栈上的指针。
尝试用
替换它 std::auto_ptr<Object> obj( new Object(oType) );
或者,如果您使用的是兼容C ++ 11的编译器,请使用
std::unique_ptr<Object> obj( new Object(oType) );
因为auto_ptr已在最新标准中弃用。