Protocol Buffers - 重複欄位



概述

repeated 資料型別是 Protobuf 的複合資料型別之一。它在 Java 中轉換為 java.util.List 介面。

繼續我們從 Protocol Buffers - 字串 章節中關於 **劇院** 的示例,以下是我們需要使用的語法,以便指示 Protobuf 我們將建立一個 **重複欄位**:

theater.proto

syntax = "proto3";
package theater;
option java_package = "com.tutorialspoint.theater";

message Theater {
   repeated string snacks = 8;
}

現在我們的 訊息 類包含一個 repeated 屬性。請注意,儘管我們有一個重複的字串,但我們也可以擁有數字、布林值、自定義資料型別列表。它還有一個 位置,這是 Protobuf 在序列化和反序列化期間使用的。成員的每個屬性都需要分配一個唯一的數字。

從 Proto 檔案建立 Java 類

要使用 Protobuf,我們現在必須使用 protoc 二進位制檔案從這個“.proto”檔案建立所需的類。讓我們看看如何做到這一點:

protoc  --java_out=. theater.proto

這將在當前目錄的 com > tutorialspoint > theater 資料夾中建立一個 TheaterOuterClass.java 類。我們在應用程式中使用此類,就像在 Protocol Buffers - 基本應用 章節中所做的那樣。

使用從 Proto 檔案建立的 Java 類

TheaterWriter.java

package com.tutorialspoint.theater;

import java.util.List;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.ArrayList;
import com.tutorialspoint.theater.TheaterOuterClass.Theater;

public class TheaterWriter{
   public static void main(String[] args) throws IOException {
      List<String> snacks = new ArrayList<>();
      snacks.add("Popcorn");
      snacks.add("Coke");
      snacks.add("Chips");
      snacks.add("Soda");
	    
      Theater theater = Theater.newBuilder()
         .addAllSnacks(snacks)
         .build();
		
      String filename = "theater_protobuf_output";
      System.out.println("Saving theater information to file: " + filename);
		
      try(FileOutputStream output = new FileOutputStream(filename)){
         theater.writeTo(output);
      }
      System.out.println("Saved theater information with following data to disk: \n" + theater);
   }
}

接下來,我們將有一個 **讀取器** 來讀取 **劇院** 資訊:

TheaterReader.java

package com.tutorialspoint.theater;

import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import com.tutorialspoint.greeting.Greeting.Greet;
import com.tutorialspoint.theater.TheaterOuterClass.Theater;
import com.tutorialspoint.theater.TheaterOuterClass.Theater.Builder;

public class TheaterReader{
   public static void main(String[] args) throws IOException {
      Builder theaterBuilder = Theater.newBuilder();

      String filename = "theater_protobuf_output";
      System.out.println("Reading from file " + filename);
        
      try(FileInputStream input = new FileInputStream(filename)) {
         Theater theater = theaterBuilder.mergeFrom(input).build();
         System.out.println(theater);
      }
   }
}

編譯專案

現在我們已經設定了 **讀取器** 和 **寫入器**,讓我們編譯專案。

mvn clean install

序列化 Java 物件

現在,編譯後,讓我們首先執行 **寫入器**:

> java -cp .\target\protobuf-tutorial-1.0.jar com.tutorialspoint.theater.TheaterWriter

Saving theater information to file: theater_protobuf_output
Saved theater information with following data to disk:
snacks: "Popcorn"
snacks: "Coke"
snacks: "Chips"
snacks: "Soda"

反序列化序列化物件

現在,讓我們執行 **讀取器** 從同一個檔案讀取:

java -cp .\target\protobuf-tutorial-1.0.jar com.tutorialspoint.theater.TheaterReader

Reading from file theater_protobuf_output
snacks: "Popcorn"
snacks: "Coke"
snacks: "Chips"
snacks: "Soda"

因此,正如我們所看到的,我們能夠透過將二進位制資料反序列化為 Theater 物件來讀取序列化的 repeated 欄位。在下一章 Protocol Buffers - 對映 中,我們將瞭解對映,這是一種複合型別。

廣告

© . All rights reserved.