在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。

相关推荐
DogDaoDao4 小时前
Android 硬件编码器参数完全指南:MediaCodec 深度解析
android·音视频·视频编解码·h264·硬编码·视频直播·mediacodec
二哈赛车手4 小时前
新人笔记---ApiFox的一些常见使用出错
java·笔记·spring
为何创造硅基生物5 小时前
C语言 结构体内存对齐规则(通俗易懂版)
c语言·开发语言
JohnnyDeng945 小时前
Android 自定义 View:Canvas 绘图与事件分发深度解析
android
吃好睡好便好5 小时前
在Matlab中绘制横直方图
开发语言·学习·算法·matlab
栗子~~5 小时前
JAVA - 二层缓存设计(本地缓冲+redis缓冲+广播所有本地缓冲失效) demo
java·redis·缓存
星寂樱易李5 小时前
iperf3 + Python-- 网络带宽、网速、网络稳定性
开发语言·网络·python
YDS8295 小时前
DeepSeek RAG&MCP + Agent智能体项目 —— RAG知识库的搭建和接口实现
java·ai·springboot·agent·rag·deepseek
仰泳之鹅5 小时前
【C语言】自定义数据类型2——联合体与枚举
c语言·开发语言·算法
nashane5 小时前
HarmonyOS 6学习:CapsLock键失效诊断与长截图完整实现指南
学习·华为·harmonyos