SlideShare a Scribd company logo
Protocol buffers
https://developers.google.com/protocol-buffers
By Manuel Correa
What are protocol buffers?
● Flexible, efficient, and automated mechanism for
Serializing data
● Over XML and JSON, Proto-Buffer is
o Binary
o Simpler
o Faster
o Smaller (space)
o Generates access classes as part of the framework
How does it work?
.proto file
What languages translate to?
● Java, C++, C, Ruby, Python, C#, Clojure, Lisp, Dart,
Erlang, Go, Android, Javascript, Matlab, Perl, Objective
C, PHP, Scala, VB, Julia, Lua, and …
● Applications
o Internal APIs
o Queue systems
o Database Objects
Quick dirty Space performance
Who is using it? source: documentation, slideshare, etc..
● Google
● Twitter
● Oracle
● ...
Reference
● Google Developer Guide
● JavaOne presentation: RESTFul Protocol
buffers
● Hadoop and Protocol Buffers at Twitter

More Related Content

PDF
Quality Assurance in PostgreSQL
PDF
Growing up new PostgreSQL developers (pgcon.org 2018)
PDF
A Shallow Survey of Alternative Languages on the JVM
PDF
I didn't know you could do that with groovy
PDF
JDD 2017: Kotlin for Java developers (Tomasz Kleszczyński)
PDF
Sprint Boot & Kotlin - Meetup.pdf
PDF
Debugging (Django) application in PyCharm
PPTX
Evolution or stagnation programming languages
Quality Assurance in PostgreSQL
Growing up new PostgreSQL developers (pgcon.org 2018)
A Shallow Survey of Alternative Languages on the JVM
I didn't know you could do that with groovy
JDD 2017: Kotlin for Java developers (Tomasz Kleszczyński)
Sprint Boot & Kotlin - Meetup.pdf
Debugging (Django) application in PyCharm
Evolution or stagnation programming languages

What's hot (20)

PDF
Groovy as a Dynamic Language
PDF
HelsinkiJS - Clojurescript for Javascript Developers
ODP
KEY
Four Python Pains
PPTX
Semana Interop: Trabalhando com IronPython e com Ironruby
PDF
Daniele Esposti - Evolution or stagnation programming languages - Codemotion ...
PDF
A short introduction to the Kotlin language for Java developers
PDF
Daniele Esposti - Evolution or stagnation programming languages - Codemotion ...
PPTX
PDF
Is this Swift for Android? A short introduction to the Kotlin language
PPTX
Boosting python web apps with protocol buffers & grpc
PPT
Google Go! language
PDF
Deep learning Type Inference for Dynamic Programming Languages
PDF
The Go programming language - Intro by MyLittleAdventure
PPTX
Intro to Kotlin Minia GDG DevFest 2017
PDF
The automation of the process of caring for the quality of the code in PHP an...
PPTX
Data serialisation using protocol buffers
PDF
Erlang: Software for a Concurrent world
ODP
Concurrent programming
Groovy as a Dynamic Language
HelsinkiJS - Clojurescript for Javascript Developers
Four Python Pains
Semana Interop: Trabalhando com IronPython e com Ironruby
Daniele Esposti - Evolution or stagnation programming languages - Codemotion ...
A short introduction to the Kotlin language for Java developers
Daniele Esposti - Evolution or stagnation programming languages - Codemotion ...
Is this Swift for Android? A short introduction to the Kotlin language
Boosting python web apps with protocol buffers & grpc
Google Go! language
Deep learning Type Inference for Dynamic Programming Languages
The Go programming language - Intro by MyLittleAdventure
Intro to Kotlin Minia GDG DevFest 2017
The automation of the process of caring for the quality of the code in PHP an...
Data serialisation using protocol buffers
Erlang: Software for a Concurrent world
Concurrent programming
Ad

Similar to Protocol buffers (20)

PDF
Python for All
PDF
Python For All | Software Professionals, QA & DevOps professionals
PDF
Cloud Native API Design and Management
PDF
"Building Modern PHP Applications" - Jackson Murtha, South Dakota Code Camp 2012
PDF
Go at uber
PPTX
Is Go Better Than Python For Data Mining
PPTX
Introduction to Jupyter notebook and MS Azure Machine Learning Studio
PPTX
Introduction to Jupyter notebook and MS Azure Machine Learning Studio
PDF
Node.js Course 2 of 2 - Advanced techniques
PPTX
Ontology Access Kit_ Workshop Intro Slides.pptx
PDF
GraphQL is actually rest
PDF
current innovations in the most critical programming language: java
PPTX
Python vs PHP: A Complete Guide to Understand the Two Technologies
PDF
Guglielmo iozzia - Google I/O extended dublin 2018
PDF
Python & Django
PDF
How to Choose a Deep Learning Framework
PDF
Programming Languages and Development Tools: State of the Art and (Hopefully)...
PDF
Data Serialization Using Google Protocol Buffers
PDF
PHP vs Python Which is Best for Web Development.pdf
PPTX
Getting Started with JAVA
Python for All
Python For All | Software Professionals, QA & DevOps professionals
Cloud Native API Design and Management
"Building Modern PHP Applications" - Jackson Murtha, South Dakota Code Camp 2012
Go at uber
Is Go Better Than Python For Data Mining
Introduction to Jupyter notebook and MS Azure Machine Learning Studio
Introduction to Jupyter notebook and MS Azure Machine Learning Studio
Node.js Course 2 of 2 - Advanced techniques
Ontology Access Kit_ Workshop Intro Slides.pptx
GraphQL is actually rest
current innovations in the most critical programming language: java
Python vs PHP: A Complete Guide to Understand the Two Technologies
Guglielmo iozzia - Google I/O extended dublin 2018
Python & Django
How to Choose a Deep Learning Framework
Programming Languages and Development Tools: State of the Art and (Hopefully)...
Data Serialization Using Google Protocol Buffers
PHP vs Python Which is Best for Web Development.pdf
Getting Started with JAVA
Ad

More from Manuel Correa (7)

PDF
How Netflix does Microservices
PPTX
Ads final project
PPT
Big table
ODP
Big table
PDF
Optimal Adaptation
PPT
RESTFul Web Services - Intro
PPT
Map Reduce
How Netflix does Microservices
Ads final project
Big table
Big table
Optimal Adaptation
RESTFul Web Services - Intro
Map Reduce

Recently uploaded (20)

PPTX
PA Analog/Digital System: The Backbone of Modern Surveillance and Communication
PDF
Network Security Unit 5.pdf for BCA BBA.
PDF
How UI/UX Design Impacts User Retention in Mobile Apps.pdf
PPTX
Detection-First SIEM: Rule Types, Dashboards, and Threat-Informed Strategy
PDF
KodekX | Application Modernization Development
PPTX
Effective Security Operations Center (SOC) A Modern, Strategic, and Threat-In...
PDF
Chapter 3 Spatial Domain Image Processing.pdf
PPT
“AI and Expert System Decision Support & Business Intelligence Systems”
PDF
cuic standard and advanced reporting.pdf
PPTX
MYSQL Presentation for SQL database connectivity
PDF
Empathic Computing: Creating Shared Understanding
PDF
Mobile App Security Testing_ A Comprehensive Guide.pdf
PDF
CIFDAQ's Market Insight: SEC Turns Pro Crypto
PDF
Reach Out and Touch Someone: Haptics and Empathic Computing
PDF
Review of recent advances in non-invasive hemoglobin estimation
PPTX
20250228 LYD VKU AI Blended-Learning.pptx
PDF
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
PDF
Advanced Soft Computing BINUS July 2025.pdf
PDF
Bridging biosciences and deep learning for revolutionary discoveries: a compr...
PDF
Advanced methodologies resolving dimensionality complications for autism neur...
PA Analog/Digital System: The Backbone of Modern Surveillance and Communication
Network Security Unit 5.pdf for BCA BBA.
How UI/UX Design Impacts User Retention in Mobile Apps.pdf
Detection-First SIEM: Rule Types, Dashboards, and Threat-Informed Strategy
KodekX | Application Modernization Development
Effective Security Operations Center (SOC) A Modern, Strategic, and Threat-In...
Chapter 3 Spatial Domain Image Processing.pdf
“AI and Expert System Decision Support & Business Intelligence Systems”
cuic standard and advanced reporting.pdf
MYSQL Presentation for SQL database connectivity
Empathic Computing: Creating Shared Understanding
Mobile App Security Testing_ A Comprehensive Guide.pdf
CIFDAQ's Market Insight: SEC Turns Pro Crypto
Reach Out and Touch Someone: Haptics and Empathic Computing
Review of recent advances in non-invasive hemoglobin estimation
20250228 LYD VKU AI Blended-Learning.pptx
Blue Purple Modern Animated Computer Science Presentation.pdf.pdf
Advanced Soft Computing BINUS July 2025.pdf
Bridging biosciences and deep learning for revolutionary discoveries: a compr...
Advanced methodologies resolving dimensionality complications for autism neur...

Protocol buffers