如何解决使用 protobuf-cpp 作为对 JNI 的依赖时出错
我使用的是来自 Scala 的 libpg_query
。为此,我创建了一个 JNI API,它使用 Protobuf 与库进行通信。不幸的是,由于来自 libpg_query
的未捕获异常,SBT 构建偶尔会导致整个 JVM 崩溃。
[libprotobuf ERROR google/protobuf/descriptor_database.cc:641] File already exists in database: protobuf/pg_query.proto
[libprotobuf FATAL google/protobuf/descriptor.cc:1371] CHECK Failed: GeneratedDatabase()->Add(encoded_file_descriptor,size):
libc++abi.dylib: terminating with uncaught exception of type google::protobuf::FatalException: CHECK Failed: GeneratedDatabase()->Add(encoded_file_descriptor,size):
这个错误似乎是众所周知的 - 通常是由将 Protobuf 生成的源双重链接到单个二进制文件引起的。这会导致生成的类重新初始化并导致二进制文件崩溃。
就我而言,这可能不是根本原因。我认为这是由于 JNI 库可以从不同的类加载器和 JVM 分支多次加载这一事实造成的 - 因为我使用一个模块中内置的 JNI 函数,所以有很多在后续模块中执行的宏的一部分。
请问,有谁知道 descriptor_database
是如何初始化的,以及我是否可以防止在我的场景中发生错误?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。