序列化要由Java等反序列化的C结构的最佳方法

前端之家收集整理的这篇文章主要介绍了序列化要由Java等反序列化的C结构的最佳方法前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
目前,我正在使用fread()/ fwrite()将C/C++结构中的一些数据保存并加载到文件中.在这个C应用程序中工作时这很好用(我可以在结构更改时重新编译以更新fread()/ fwrite()的sizeof()参数,但是如何在不事先知道的情况下将此文件加载到其他程序中C结构的sizeof()?

特别是,我编写了这个其他Java应用程序,可视化该C struct二进制文件中包含的数据,但我想了解如何读取该二进制文件的一般解决方案. (而不是每当C结构发生变化时,我都必须在Java应用程序源中手动输入sizeof();)

我正在考虑序列化到某种文本或XML,但我不知道从哪里开始(如何在C中序列化,然后如何在Java中以及将来可能的其他语言中反序列化),如果是这里建议结构的一个成员是一个浮点数组,它可以以二进制格式向上移动~50 MB(我有数百个这样的数据文件可以读写).

C结构很简单(没有严格的嵌套或指针引用),如下所示:

struct MyStructure {
    char *title;
    int id;
    int param1;
    int param2;
    float *data;
}

最容易改变的部分是param整数.

我有什么选择?

解决方法

如果您可以控制两个代码库,则应考虑使用 Protocol Buffers.

猜你在找的Java相关文章