我可以对/从JSON序列化/反序列化flatbuffers吗?

时间:2018-01-11 21:17:27

标签: c++ json serialization deserialization flatbuffers

是否可以在JSON之间序列化/反序列化flatbuffers?

我真正想做的是将flatbuffers保存为JSON,允许人们更改他们想要的任何值,然后将JSON读回到flatbuffer中(并在应用程序中以某种方式使用它)。

也许有另一种方法可以达到同样的效果。我们正在使用C ++。

3 个答案:

答案 0 :(得分:4)

是的,这是FlatBuffers中的内置功能。请参阅此处的“文本和架构解析”:https://google.github.io/flatbuffers/flatbuffers_guide_use_cpp.html 另请参阅test.cpp中的ParseAndGenerateTextTest()registry.h

中的示例

答案 1 :(得分:1)

http://frogermcs.github.io/json-parsing-with-flatbuffers-in-android/

FlatBuffers库最近越来越受欢迎。如果您查看了上一个Android Performance Patterns系列,那么Colt McAnlis会在不同的视频中多次提及它。可能您还记得Facebook关于迁移到FlatBuffers的公告。不久前,我发布了有关如何在Android中开始使用它的帖子。

java

public class FlatBuffersParser {

    static {
        System.loadLibrary("FlatBuffersParser");
    }

    public ByteBuffer parseJson(String json, String schema) {
        final byte[] bytes = parseJsonNative(json, schema);
        return ByteBuffer.wrap(bytes);
    }

    private native byte[] parseJsonNative(String json, String schema);
}

** C ++ **

#ifndef __MAIN_H__
#define __MAIN_H__

#include <flatbuffers/idl.h>
#include "main.h"

JNIEXPORT jbyteArray JNICALL
Java_frogermcs_io_flatbuffersparser_FlatBuffersParser_parseJsonNative(JNIEnv *env,
                                                                      jobject instance,
                                                                      jstring json_,
                                                                      jstring schema_) {
    const char *json = env->GetStringUTFChars(json_, 0);
    const char *schema = env->GetStringUTFChars(schema_, 0);

    flatbuffers::Parser parser;
    bool ok = parser.Parse(schema) && parser.Parse(json);

    env->ReleaseStringUTFChars(json_, json);
    env->ReleaseStringUTFChars(schema_, schema);

    if (ok) {
        flatbuffers::uoffset_t length = parser.builder_.GetSize();
        jbyteArray result = env->NewByteArray(length);
        uint8_t *bufferPointer = parser.builder_.GetBufferPointer();
        env->SetByteArrayRegion(result, 0, length, reinterpret_cast<jbyte *>(bufferPointer));
        return result;
    }
}

#endif // __MAIN_H__

答案 2 :(得分:1)

这就是我用的

包含flatbuffers模式的sample.fbs文件。

table sample
{
    firstName: string;
    lastName: string;
    age: int;
}

root_type sample;

将JSON解析为Flatbuffers二进制并返回JSON的程序

#include <iostream>
#include <string>

#include "flatbuffers/idl.h"

int main()
{
    std::string input_json_data = "{ \
            firstName: \"somename\", \
            lastName: \"someothername\", \
            age: 21 \
        } \
        ";

    std::string schemafile;
    std::string jsonfile;
    bool ok = flatbuffers::LoadFile("sample.fbs", false, &schemafile);
    if (!ok) {
        std::cout << "load file failed!" << std::endl;
        return -1;
    }

    flatbuffers::Parser parser;
    parser.Parse(schemafile.c_str());
    if (!parser.Parse(input_json_data.c_str())) {
        std::cout << "flatbuffers parser failed with error : " << parser.error_ << std::endl;
        return -1;
    }

    std::string jsongen;
    if (!GenerateText(parser, parser.builder_.GetBufferPointer(), &jsongen)) {
        std::cout << "Couldn't serialize parsed data to JSON!" << std::endl;
        return -1;
    }

    std::cout << "intput json" << std::endl
              << input_json_data << std::endl
              << std::endl
              << "output json" << std::endl
              << jsongen << std::endl;

    return 0;
}

产生以下输出

$ ./build/output/test_json_fb 
intput json
{             firstName: "somename",             lastName: "someothername",             age: 21         }         

output json
{
  firstName: "somename",
  lastName: "someothername",
  age: 21
}

通过引用页面https://github.com/google/flatbuffers/blob/master/samples/sample_text.cpp

创建