如何将 RapidJSON 文档序列化为字符串?
How to serialize RapidJSON document to a string?
如何将RapidJSON文档序列化为字符串?
在所有示例中,序列化文本都通过 FileStream
重定向到标准输出,但我需要将其重定向到字符串变量。
像这样:
const char *GetJsonText()
{
rapidjson::StringBuffer buffer;
buffer.Clear();
rapidjson::Writer<rapidjson::StringBuffer> writer(buffer);
doc.Accept(writer);
return strdup( buffer.GetString() );
}
当然你必须在 return 上调用 free(),或者做:
return string( buffer.GetString() );
相反。
示例代码:
Document document;
const char *json = " { \"x\" : \"0.01\", \"y\" :\"0.02\" , \"z\" : \"0.03\"} ";
document.Parse<0>(json);
//convert document to string
StringBuffer strbuf;
strbuf.Clear();
Writer<StringBuffer> writer(strbuf);
document.Accept(writer);
std::string ownShipRadarString = strbuf.GetString();
std::cout << "**********************************************" << ownShipRadarString << std::endl;
在first page of the project中,代码已经展示了如何将文档序列化为字符串(stringify a document):
// 3. Stringify the DOM
StringBuffer buffer;
Writer<StringBuffer> writer(buffer);
d.Accept(writer);
// Output {"project":"rapidjson","stars":11}
std::cout << buffer.GetString() << std::endl;
buffer.GetString()
这里returns一个const char*
类型的字符串。它还有一个 buffer.GetSize()
用于返回输出字符串的大小。所以,如果你想把它转换成 std::string
,最好的方法是:
std::string s(buffer.GetString(), buffer.GetSize());
tutorial.cpp也展示了同样的东西,除了RapidJSON的其他常见用法。
为了避免复制字符串内容,您可以创建一个 rapidjson 流概念 class 来包装现有的 std::string,参考:https://github.com/Tencent/rapidjson/issues/846#issuecomment-298088278
事实上,并不是那里实现的所有方法都是必需的。应该这样做:
void writeDocumentToString(const rapidjson::Document& document,
std::string& output)
{
class StringHolder
{
public:
typedef char Ch;
StringHolder(std::string& s) : s_(s) { s_.reserve(4096); }
void Put(char c) { s_.push_back(c); }
void Flush() { return; }
private:
std::string& s_;
};
StringHolder os(output);
rapidjson::Writer<StringHolder> writer(os);
document.Accept(writer);
}
如何将RapidJSON文档序列化为字符串?
在所有示例中,序列化文本都通过 FileStream
重定向到标准输出,但我需要将其重定向到字符串变量。
像这样:
const char *GetJsonText()
{
rapidjson::StringBuffer buffer;
buffer.Clear();
rapidjson::Writer<rapidjson::StringBuffer> writer(buffer);
doc.Accept(writer);
return strdup( buffer.GetString() );
}
当然你必须在 return 上调用 free(),或者做:
return string( buffer.GetString() );
相反。
示例代码:
Document document;
const char *json = " { \"x\" : \"0.01\", \"y\" :\"0.02\" , \"z\" : \"0.03\"} ";
document.Parse<0>(json);
//convert document to string
StringBuffer strbuf;
strbuf.Clear();
Writer<StringBuffer> writer(strbuf);
document.Accept(writer);
std::string ownShipRadarString = strbuf.GetString();
std::cout << "**********************************************" << ownShipRadarString << std::endl;
在first page of the project中,代码已经展示了如何将文档序列化为字符串(stringify a document):
// 3. Stringify the DOM
StringBuffer buffer;
Writer<StringBuffer> writer(buffer);
d.Accept(writer);
// Output {"project":"rapidjson","stars":11}
std::cout << buffer.GetString() << std::endl;
buffer.GetString()
这里returns一个const char*
类型的字符串。它还有一个 buffer.GetSize()
用于返回输出字符串的大小。所以,如果你想把它转换成 std::string
,最好的方法是:
std::string s(buffer.GetString(), buffer.GetSize());
tutorial.cpp也展示了同样的东西,除了RapidJSON的其他常见用法。
为了避免复制字符串内容,您可以创建一个 rapidjson 流概念 class 来包装现有的 std::string,参考:https://github.com/Tencent/rapidjson/issues/846#issuecomment-298088278
事实上,并不是那里实现的所有方法都是必需的。应该这样做:
void writeDocumentToString(const rapidjson::Document& document,
std::string& output)
{
class StringHolder
{
public:
typedef char Ch;
StringHolder(std::string& s) : s_(s) { s_.reserve(4096); }
void Put(char c) { s_.push_back(c); }
void Flush() { return; }
private:
std::string& s_;
};
StringHolder os(output);
rapidjson::Writer<StringHolder> writer(os);
document.Accept(writer);
}