2024 年 11 月 7 日宣布的变更

2024 年 11 月 7 日宣布的 Protocol Buffers 变更。

以下各节介绍了计划在 v30 版本(预计于 2025 年第一季度发布)中进行的重大变更。此外还包括一些非重大但可能需要您采取行动的变更。这些是 10 月 2 日新闻文章中提到的变更之外的补充。

这些描述是我们预期的变更实现方式,但由于软件的灵活性,其中一些变更可能不会最终实施,或者可能与本主题中的描述有所不同。

在 Arena 上清除 Oneof 消息后引入 ASAN Poisoning

此变更增加了一项强化检查,影响使用 Arena 的 C++ protobufs。在 protobuf Arena 上分配的 Oneof 消息现在将在调试模式下被清除,并在 ASAN 模式下被“投毒”(poisoned)。调用 clear 后,未来尝试使用该内存区域将在 ASAN 中导致崩溃,报告为 use-after-free 错误。

此实现需要 C++17

Python map 字段的 setdefault 行为变更

从 v30 开始,setdefault 对于 ScalarMap 将类似于 dict,但键和值都必须设置。对于 MessageMapssetdefault 将被拒绝。

移除已弃用的 py_proto_library 宏

protobuf.bzl 中已弃用的内部 py_proto_library Bazel 宏将在 v30.x 中被移除。

应将其替换为官方的 py_proto_library,该库将从 v29.x 开始移至 protobuf 的 bazel/py_proto_library 中。在 v29.x 之前,此实现可在 rules_python 中找到。

Python 嵌套消息类的 __qualname__ 包含外部消息名称

Python 嵌套消息类的 __qualname__ 现在包含外部消息的名称。在 v30 之前,对于嵌套消息,__qualname____name__ 的结果相同,即不包含外部消息的名称。

例如:

message Foo {
  message Bar {
    bool bool_field = 1;
  }
}
nested = test_pb2.Foo.Bar()
self.assertEqual('Bar', nested.__class__.__name__)
self.assertEqual('Foo.Bar', nested.__class__.__qualname__) # It was 'Bar' before

停止发布 C++ CocoaPods

在 v30 中,我们将停止发布 C++ CocoaPods 版本,该版本自 v4.x.x 以来一直处于损坏状态。C++ 用户应直接使用我们的 GitHub release

Ruby 和 PHP 在 JSON 解析中的错误

v30 根据 JSON 规范修复了在解析数字字段中的字符串时不合规的问题。

此修复不会伴随主版本号的提升,但 Ruby 和 PHP 现在将对数字字段中的非数字字符串(例如“”、“12abc”、“abc”)引发错误。v29.x 将针对这些错误情况包含警告。