SlideShare a Scribd company logo
Experience
Protocol Buffer
on Android
HELLO!
I am Richard Chang
Android Engineer
Worked for HTC, Movial, VMFive and AndroVideo
You can find me via chiel99 AT gmail.com
Outline
● Introduce Protocol Buffers
● Why Protocol Buffers
● How to use Protocol Buffers
● Protocol buffer meets Android
● Demo
● Reference
https://github.com/chiel99/ExperienceProtobuf
What are
Protocol Buffers?
Protocol buffers are Google's
language-neutral, platform-neutral,
extensible mechanism for serializing
structured data
From: https://developers.google.com/protocol-buffers/
Serialize
Deserialize
Experience protocol buffer on android
Why
Protocol Buffers?
Benefits
● Speed
○ Fast
● Size
○ Small
○ Serialize to binary-format stream
● Backward Compatible
● Multiple programming language support
○ C++ / Java / Python / C# / Go...etc
● Easy to define the data schema
How to use
protocol buffers?
Usages
● Install protoc (protocol buffer compiler) and related libs
○ steps
● Write a .proto file
● Use protoc to generate the Java/C++/Python... source code
○ protoc --cpp_out=./cpp --java_out=./java sample.proto
● Add related libs to your project
● Put the generated source code to your project
● writeTo() and parseFrom()
● Happy coding with Protocol Buffers!
Sample
Protocol Buffers meet Android
● AOSP/external/protobuf/
○ protoc => aprotoc
○ AOSP is not following the latest version
● Dex 65535 method count issue
● Apk size issue
Protocol Buffers for Java
Lite version Micro version Nano version
Lib size 128 KB 21 KB 43 KB
Generated Java
class size*
7~8x 1.2~1.3x 1x
Object creation Builder Constructor Constructor
Object
operations
Builder /
Setter / Getter
Setter / Getter public member
Repeated
objects
List List Array
Demo
Speed and Size comparison with GSON
● Speed
○ Serialize: ~10x faster (40 ms v.s 400 ms)
○ Deserialize: ~2x faster (15 ms v.s 30 ms)
● Serialized data size
○ ~2x smaller (24 KB v.s 45 KB)
● Lib size
○ ~10x smaller (21 KB v.s 232 KB)
Drawbacks
● Human unreadable format
● Need tool (protoc) to generate source code
● Most network services are JSON based?
Thanks!
Any questions?
You can find the sample code on github:
https://github.com/chiel99/ExperienceProtobuf
Reference
● https://developers.google.com/protocol-buffers/
● https://github.com/android/platform_external_protobuf
● AOSP: frameworks/native/opengl/libs/GLES_trace
● https://github.com/square/wire
● https://github.com/Biuni/PokemonGO-Pokedex

More Related Content

PDF
Introduction to protocol buffer
PPTX
Thrift vs Protocol Buffers vs Avro - Biased Comparison
PDF
Beyond JSON - An Introduction to FlatBuffers
PPTX
Avro - More Than Just a Serialization Framework - CHUG - 20120416
PPTX
Serialization and performance by Sergey Morenets
PDF
Serialization (Avro, Message Pack, Kryo)
PDF
ApacheCon09: Avro
PPT
Building scalable and language independent java services using apache thrift
Introduction to protocol buffer
Thrift vs Protocol Buffers vs Avro - Biased Comparison
Beyond JSON - An Introduction to FlatBuffers
Avro - More Than Just a Serialization Framework - CHUG - 20120416
Serialization and performance by Sergey Morenets
Serialization (Avro, Message Pack, Kryo)
ApacheCon09: Avro
Building scalable and language independent java services using apache thrift

What's hot (20)

PDF
Go language presentation
PDF
Serialization in Go
PPTX
PHP Internals
PDF
3 apache-avro
PPTX
Apache Avro and Messaging at Scale in LivePerson
PPTX
Facebook thrift
PPTX
Taming the resource tiger
PPT
A First Look at Google's Go Programming Language
PDF
Structured web programming
PDF
A Shallow Survey of Alternative Languages on the JVM
ODP
Fscons scalable appplication transfers
PPTX
Introduction to go lang
PDF
Modularity problems
PDF
Dart the better Javascript 2015
PPTX
PPTX
PPTX
Apache Avro in LivePerson [Hebrew]
PPTX
Avro intro
PDF
3 avro hug-2010-07-21
Go language presentation
Serialization in Go
PHP Internals
3 apache-avro
Apache Avro and Messaging at Scale in LivePerson
Facebook thrift
Taming the resource tiger
A First Look at Google's Go Programming Language
Structured web programming
A Shallow Survey of Alternative Languages on the JVM
Fscons scalable appplication transfers
Introduction to go lang
Modularity problems
Dart the better Javascript 2015
Apache Avro in LivePerson [Hebrew]
Avro intro
3 avro hug-2010-07-21
Ad

Viewers also liked (13)

DOCX
Seminar on Android Auto
PDF
Android Open Accessory Protocol - Turn Your Linux machine as ADK
PDF
Leveraging the Android Open Accessory Protocol
PDF
An Empirical Evaluation of VoIP Playout Buffer Dimensioning in Skype, Google ...
PPTX
Protocol buffers
PDF
Illustration of TextSecure's Protocol Buffer usage
PPTX
Protocol Buffer.ppt
PDF
Data Serialization Using Google Protocol Buffers
PPTX
Google Protocol Buffers
PDF
Axolotl Protocol: An Illustrated Primer
PDF
Introduction of Android Auto
KEY
Hadoop, Pig, and Twitter (NoSQL East 2009)
KEY
Protocol Buffers and Hadoop at Twitter
Seminar on Android Auto
Android Open Accessory Protocol - Turn Your Linux machine as ADK
Leveraging the Android Open Accessory Protocol
An Empirical Evaluation of VoIP Playout Buffer Dimensioning in Skype, Google ...
Protocol buffers
Illustration of TextSecure's Protocol Buffer usage
Protocol Buffer.ppt
Data Serialization Using Google Protocol Buffers
Google Protocol Buffers
Axolotl Protocol: An Illustrated Primer
Introduction of Android Auto
Hadoop, Pig, and Twitter (NoSQL East 2009)
Protocol Buffers and Hadoop at Twitter
Ad

Similar to Experience protocol buffer on android (20)

PDF
Introduction to DevOps and the Practical Use Cases at Credit OK
PDF
Enterprise-Grade DevOps Solutions for a Start Up Budget
PDF
The Business Advantage of Adopting Python Development.pdf
PDF
Apigility introduction v2 (glasgow php)
PPTX
Introduction to Python Programming in Civil Engineering
PDF
An hour with WebRTC FIC UDC
PPTX
InnovateQASeattle2024_RoyYap_Intro to Robot Framework.pptx
PDF
Security in CI/CD Pipelines: Tips for DevOps Engineers
PDF
Test Driven Development with PHP
PDF
TEE - kernel support is now upstream. What this means for open source security
PPTX
Python Programming Essentials - M2 - Introduction to Python
PDF
(phpconftw2012) PHP as a Middleware in Embedded Systems
PPTX
Boosting python web apps with protocol buffers & grpc
PDF
Pentester++
PDF
Building FirefoxOS apps with Clojurescript
PDF
Introduction to Apigility
PDF
Behaviour Testing and Continuous Integration with Drupal
PDF
Возможности интерпретатора Python в NX-OS
PPTX
Creating a reasonable project boilerplate
PDF
Writing Fast Code - PyCon HK 2015
Introduction to DevOps and the Practical Use Cases at Credit OK
Enterprise-Grade DevOps Solutions for a Start Up Budget
The Business Advantage of Adopting Python Development.pdf
Apigility introduction v2 (glasgow php)
Introduction to Python Programming in Civil Engineering
An hour with WebRTC FIC UDC
InnovateQASeattle2024_RoyYap_Intro to Robot Framework.pptx
Security in CI/CD Pipelines: Tips for DevOps Engineers
Test Driven Development with PHP
TEE - kernel support is now upstream. What this means for open source security
Python Programming Essentials - M2 - Introduction to Python
(phpconftw2012) PHP as a Middleware in Embedded Systems
Boosting python web apps with protocol buffers & grpc
Pentester++
Building FirefoxOS apps with Clojurescript
Introduction to Apigility
Behaviour Testing and Continuous Integration with Drupal
Возможности интерпретатора Python в NX-OS
Creating a reasonable project boilerplate
Writing Fast Code - PyCon HK 2015

Recently uploaded (20)

PDF
Odoo Companies in India – Driving Business Transformation.pdf
PPTX
history of c programming in notes for students .pptx
PDF
Raksha Bandhan Grocery Pricing Trends in India 2025.pdf
PDF
Internet Downloader Manager (IDM) Crack 6.42 Build 41
PDF
Adobe Illustrator 28.6 Crack My Vision of Vector Design
PPTX
Agentic AI : A Practical Guide. Undersating, Implementing and Scaling Autono...
PPTX
Lecture 3: Operating Systems Introduction to Computer Hardware Systems
PDF
medical staffing services at VALiNTRY
PDF
T3DD25 TYPO3 Content Blocks - Deep Dive by André Kraus
PDF
Adobe Premiere Pro 2025 (v24.5.0.057) Crack free
PPTX
Embracing Complexity in Serverless! GOTO Serverless Bengaluru
PDF
Designing Intelligence for the Shop Floor.pdf
PDF
top salesforce developer skills in 2025.pdf
PDF
System and Network Administration Chapter 2
PDF
EN-Survey-Report-SAP-LeanIX-EA-Insights-2025.pdf
PDF
Addressing The Cult of Project Management Tools-Why Disconnected Work is Hold...
PDF
wealthsignaloriginal-com-DS-text-... (1).pdf
PDF
Understanding Forklifts - TECH EHS Solution
PDF
Upgrade and Innovation Strategies for SAP ERP Customers
PPTX
CHAPTER 2 - PM Management and IT Context
Odoo Companies in India – Driving Business Transformation.pdf
history of c programming in notes for students .pptx
Raksha Bandhan Grocery Pricing Trends in India 2025.pdf
Internet Downloader Manager (IDM) Crack 6.42 Build 41
Adobe Illustrator 28.6 Crack My Vision of Vector Design
Agentic AI : A Practical Guide. Undersating, Implementing and Scaling Autono...
Lecture 3: Operating Systems Introduction to Computer Hardware Systems
medical staffing services at VALiNTRY
T3DD25 TYPO3 Content Blocks - Deep Dive by André Kraus
Adobe Premiere Pro 2025 (v24.5.0.057) Crack free
Embracing Complexity in Serverless! GOTO Serverless Bengaluru
Designing Intelligence for the Shop Floor.pdf
top salesforce developer skills in 2025.pdf
System and Network Administration Chapter 2
EN-Survey-Report-SAP-LeanIX-EA-Insights-2025.pdf
Addressing The Cult of Project Management Tools-Why Disconnected Work is Hold...
wealthsignaloriginal-com-DS-text-... (1).pdf
Understanding Forklifts - TECH EHS Solution
Upgrade and Innovation Strategies for SAP ERP Customers
CHAPTER 2 - PM Management and IT Context

Experience protocol buffer on android