perfetto原理之ProtoZero

设计

ProtoZero是一个零拷贝,零分配,零系统调用的protobuf序列化库,主要用于在Perfetto里实现跟踪记录.

动机

ProtoZero设计和充分优化用于proto序列化,并用在Perfetto的所有跟踪路径上. 反序列化主要在稍后的离线处理工具中使用(比如,TraceProcess).零拷贝,零分配,零系统调用主要是在序列化代码中.

Perfetto在跟踪的快速路径中广泛使用protobuf. Perfetto中的每种跟踪事件都是一个proto (TracePacket). 这使得事件是强类型的,使用团队间容易理解的语言并易于保持兼容性.

跟踪的快速路径需要尽可能低的开销,因为插桩代码遍布Android和Chrome的代码之中,性能至关重要.

这里的开销不仅仅指插桩点代码的CPU时间,. 跟踪系统中一个很大的开销来源是由检测点的工作集引入的,特别是额外的I缓存和D缓存未命中,这将减慢跟踪检测点之后的非跟踪代码的速度。

ProtoZero与libprotobuf等规范C++protobuf库的主要设计差异如下:

  • 将序列化和反序列化看作是不同的应用场景的不同代码
  • 优化序列化路径上的二进制大小和工作集大小.
  • 忽略protobuf的大多数错误检查和长尾特性(重复与可选、完整类型检查)。
  • ProtoZero不是为了设计为通用的protobuf序列化和反序列化功能,而是采用了大量定制的手段,以将跟踪写入代码保持在最低销耗,并允许编译器查看其体系结构层。
  • ProtoZe
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

self-motivation

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值