Description
Official Google Protocol Buffer Repo
Protocol Buffers alternatives and similar packages
Based on the "Serialization" category.
Alternatively, view Protobuf alternatives based on common mentions on social networks and blogs.
-
Protobuf.NET
Protocol buffers is the name of the binary serialization format used by Google for much of their data communications -
MessagePack for C# (.NET, .NET Core, Unity, Xamarin)
Extremely Fast MessagePack Serializer for C#(.NET, .NET Core, Unity, Xamarin). / msgpack.org[C#] -
Bond
cross-platform framework for working with schematized data. It supports cross-language de/serialization and powerful generic mechanisms for efficiently manipulating data. -
ZeroFormatter
Fastest C# Serializer and Infinitely Fast Deserializer for .NET, .NET Core and Unity. -
Utf8Json
Fast and Zero Allocation JSON Serializer for C#(.NET, .NET Core, Unity and Xamarin), this serializer write/read directly to UTF8 binary so boostup performance. -
FileHelpers
free and easy to use .NET library to import or export data from fixed length or delimited records in files, strings or streams. -
Ceras
Very fast binary serializer for .NET/Core/Unity; huge set of features, can be used for easy networking, handles circular references, polymorphism, ...
Get performance insights in less than 4 minutes
* Code Quality Rankings and insights are calculated and provided by Lumnify.
They vary from L1 to L5 with "L5" being the highest. Visit our partner's website for more details.
Do you think we are missing an alternative of Protocol Buffers or a related project?
README
Protocol Buffers - Google's data interchange format
Copyright 2008 Google Inc.
https://developers.google.com/protocol-buffers/
Overview
Protocol Buffers (a.k.a., protobuf) are Google's language-neutral, platform-neutral, extensible mechanism for serializing structured data. You can find protobuf's documentation on the Google Developers site.
This README file contains protobuf installation instructions. To install protobuf, you need to install the protocol compiler (used to compile .proto files) and the protobuf runtime for your chosen programming language.
Protocol Compiler Installation
The protocol compiler is written in C++. If you are using C++, please follow the [C++ Installation Instructions](src/README.md) to install protoc along with the C++ runtime.
For non-C++ users, the simplest way to install the protocol compiler is to download a pre-built binary from our release page:
https://github.com/protocolbuffers/protobuf/releases
In the downloads section of each release, you can find pre-built binaries in zip packages: protoc-$VERSION-$PLATFORM.zip. It contains the protoc binary as well as a set of standard .proto files distributed along with protobuf.
If you are looking for an old version that is not available in the release page, check out the maven repo here:
https://repo1.maven.org/maven2/com/google/protobuf/protoc/
These pre-built binaries are only provided for released versions. If you want to use the github master version at HEAD, or you need to modify protobuf code, or you are using C++, it's recommended to build your own protoc binary from source.
If you would like to build protoc binary from source, see the [C++ Installation Instructions](src/README.md).
Protobuf Runtime Installation
Protobuf supports several different programming languages. For each programming language, you can find instructions in the corresponding source directory about how to install protobuf runtime for that specific language:
Language | Source | Ubuntu | MacOS | Windows |
---|---|---|---|---|
C++ (include C++ runtime and protoc) | [src](src) | ![]() ![]() ![]() |
![]() ![]() |
|
Java | [java](java) | ![]() ![]() ![]() ![]() |
||
Python | [python](python) | ![]() ![]() ![]() ![]() ![]() ![]() ![]() ![]() ![]() ![]() |
![]() ![]() ![]() |
![]() |
Objective-C | [objectivec](objectivec) | ![]() ![]() ![]() ![]() |
||
C# | [csharp](csharp) | ![]() |
![]() |
|
JavaScript | [js](js) | ![]() |
![]() |
|
Ruby | [ruby](ruby) | ![]() ![]() ![]() ![]() ![]() |
![]() ![]() ![]() ![]() ![]() |
|
Go | protocolbuffers/protobuf-go | |||
PHP | [php](php) | ![]() ![]() ![]() |
![]() ![]() |
|
Dart | dart-lang/protobuf |
Quick Start
The best way to learn how to use protobuf is to follow the tutorials in our developer guide:
https://developers.google.com/protocol-buffers/docs/tutorials
If you want to learn from code examples, take a look at the examples in the [examples](examples) directory.
Documentation
The complete documentation for Protocol Buffers is available via the web at: