在Android中如何使用Protobuf上传协议

在 Android 中使用 Protobuf(Protocol Buffers)主要分为以下几个步骤:


✅ 1. 添加 Protobuf 插件和依赖

在项目的 build.gradle(Project 级)文件中添加 Google 的 Maven 仓库(通常默认已有):

复制代码
buildscript {
    dependencies {
        classpath 'com.google.protobuf:protobuf-gradle-plugin:0.9.4' // 最新版本可查 MavenCentral
    }
}

在模块级的 build.gradle(通常是 app/build.gradle)中:

复制代码
plugins {
    id 'com.android.application'
    id 'com.google.protobuf'
}

android {
    // ...
}

dependencies {
    implementation 'com.google.protobuf:protobuf-javalite:3.24.0' // 推荐使用 javalite 版本
}

protobuf {
    protoc {
        artifact = 'com.google.protobuf:protoc:3.24.0' // 对应版本
    }
    generateProtoTasks {
        all().each { task ->
            task.builtins {
                java {
                    option 'lite' // 使用 lite 版本更适合 Android
                }
            }
        }
    }
}

✅ 2. 创建 .proto 文件

src/main/proto/ 目录下创建 .proto 文件,例如:

person.proto

复制代码
syntax = "proto3";

option java_package = "com.example.myapp"; // 替换为你的包名
option java_outer_classname = "PersonProto"; // 生成的外部类名

message Person {
  string name = 1;
  int32 id = 2;
  string email = 3;
}

✅ 3. 编译生成 Java 类

构建项目(Build > Rebuild Project./gradlew build)后,Gradle 会自动生成 Java 类(在 build/generated/ 目录下)。

你可以这样使用:

复制代码
// 创建对象
PersonProto.Person person = PersonProto.Person.newBuilder()
    .setName("Alice")
    .setId(123)
    .setEmail("alice@example.com")
    .build();

// 序列化
byte[] bytes = person.toByteArray();

// 反序列化
PersonProto.Person parsed = PersonProto.Person.parseFrom(bytes);

✅ 4. Protobuf 使用建议(在 Android 中)

  • 推荐使用 protobuf-javalite:因为它是为移动端优化的,体积更小,依赖更少。

  • 避免嵌套太多层次的 message:保持结构简单,便于维护和性能更好。

  • 可以结合 Room 使用 Protobuf 类型作为字段:需要自定义 TypeConverter。

相关推荐
风筝在晴天搁浅13 小时前
手撕单例模式
java·开发语言·单例模式
BetterNow.13 小时前
安卓内存Previous为什么可以算进freeRam
android·linux·安卓·安卓性能·安卓内存
炽烈小老头13 小时前
【每天学习一点算法 2026/04/29】最长连续序列
学习·算法
星空ξ13 小时前
OpenCode + Oh-My-OpenCode 配置指南:集成 GitHub Copilot 模型与 Java LSP (jdtls)
java·github·copilot·opencode·oh-my-opencode
Seven9713 小时前
Tomcat Request请求处理:Container设计
java
逸Y 仙X13 小时前
文章十五:ElasticSearch 运用ingest加工索引数据
java·大数据·elasticsearch·搜索引擎·全文检索
库奇噜啦呼13 小时前
【iOS】源码学习-类与对象底层原理
学习·ios·cocoa
码云数智-园园13 小时前
PHP 8.x 命名的参数与属性(Attribute):告别注释,构建真正的元数据
android·ide·android studio
0pen113 小时前
ZygiskNext 源码解析(三):zygiskd 的模块管理、memfd 与 companion
android·安全·开源
Android_xiong_st13 小时前
(原创)2026安卓面试复盘
android·面试·职场和发展