Android Studio 配置并使用Protocol Buffer生成java文件

本文详细介绍了如何在Android Studio中配置protobuf,包括在Project和Module的build.gradle文件中添加依赖和插件,指定proto文件路径,以及设置protobuf版本和生成任务。同时,提供了proto文件的编写示例,并指出了编译产物的路径。最后,给出了参考链接以便进一步学习。
摘要由CSDN通过智能技术生成

一、android studio配置

1.1、 Project的build.gradle
buildscript {
  repositories {
    mavenCentral()
  }
  dependencies {
    classpath 'com.google.protobuf:protobuf-gradle-plugin:0.8.17'
  }
}

目前Protobuf Plugin for Gradle最版本是0.8.17,安装该版本的插件需要Gradle 5.6Java 8,在Maven Central可用

1.2、Module的build.gradle
1.2.1、声明依赖的protobuf插件(有两种方式)

1.2.1.1、采用apply方法

apply plugin: 'com.android.application'  // or 'com.android.library'
apply plugin: 'com.google.protobuf' //必须apply plugin: 'com.android.application'语句后,再声明
....

1.2.1.2、采用Gradle plugin DSL

plugins {
    id 'com.android.application'
    id 'com.google.protobuf' //这个没有先后顺序
}
1.2.2、指定被编译proto文件所在的路径
android {
	.....
    sourceSets {
        main {
            java {
                srcDir 'src/main/java'
            }
            proto {
                srcDir 'src/main/proto'
            }
        }
    }
    ....
}

注意:不指定时,默认与java同级的目录(即${ProjectName}/app/src/main/java)

1.2.3、添加protobuf依赖与proto生成任务(有两种方式)

1.2.3.1、采用版本为3.0.x~3.7.xProtobuf

dependencies {
  // You need to depend on the lite runtime library, not protobuf-java
  implementation 'com.google.protobuf:protobuf-lite:3.0.0'
}

protobuf {
  protoc {
    // You still need protoc like in the non-Android case
    artifact = 'com.google.protobuf:protoc:3.7.0'
  }
  plugins {
    javalite {
      // The codegen for lite comes as a separate artifact
      artifact = 'com.google.protobuf:protoc-gen-javalite:3.0.0'
    }
  }
  generateProtoTasks {
    all().each { task ->
      task.builtins {
        // In most cases you don't need the full Java output
        // if you use the lite output.
        remove java
      }
      task.plugins {
        javalite { }
      }
    }
  }
}

1.2.3.2、采用版本为3.8.0之后的Protobuf

dependencies {
  // You need to depend on the lite runtime library, not protobuf-java
  //implementation 'com.google.protobuf:protobuf-javalite:3.8.0'
  //目前protobuf-javalite的最新版本
  implementation 'com.google.protobuf:protobuf-javalite:3.18.1'  
}

protobuf {
  protoc {
    //指定protobuf compile版本  
    //artifact = 'com.google.protobuf:protoc:3.8.0'
    //目前protoc的最新版本
    artifact = 'com.google.protobuf:protoc:3.18.1'  
  }
  generateProtoTasks {
    all().each { task ->
      task.builtins {
        java {
          option "lite"
        }
      }
    }
  }
}

注意:protobuf-javalitprotoc的最新版本可在maven仓库搜索该两个字眼得到

二、编写proto文件

${ProjectName}/app/src/main/proto/addressbook.proto

syntax = "proto2";

package tutorial;

option java_multiple_files = true;
option java_package = "com.example.tutorial.protos";
option java_outer_classname = "AddressBookProtos";

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

  enum PhoneType {
    MOBILE = 0;
    HOME = 1;
    WORK = 2;
  }

  message PhoneNumber {
    optional string number = 1;
    optional PhoneType type = 2 [default = HOME];
  }

  repeated PhoneNumber phones = 4;
}

message AddressBook {
  repeated Person people = 1;
}

最后编译产物路径:${ProjectName}/app/build/generated/source/proto

protobuf 语法教程

三、使用proto编译产物

Person john =
                Person.newBuilder()
                        .setId(1234)
                        .setName("John Doe")
                        .setEmail("jdoe@example.com")
                        .addPhones(
                                Person.PhoneNumber.newBuilder()
                                        .setNumber("555-4321")
                                        .setType(Person.PhoneType.HOME))
                        .build();
AddressBook.Builder addressBookBuilder = AddressBook.newBuilder();
addressBookBuilder.addPeople(john);
AddressBook addressBook = addressBookBuilder.build();

四、参考

android studio 配置protobuf 参考
Demo

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值