Flat Buffers - 数字
概述
数字包括Flat Buffers类型,如int、short、float、double,它们是Flat Buffers的基本构建块。在我们使用的语言(例如 Java、Python 等)中,它分别转换为int、short float、double。
继续使用Flat Buffers - 字符串一章中的Theater 示例,以下是我们需要指示Flat Buffers我们将创建数字的语法 −
theater.fbs
namespace com.tutorialspoint.theater; table Theater { total_capcity:int; mobile:long; base_ticket_price:float; } root_type Theater;
现在我们的表包含数字属性。默认值为 0 或 0.0(视情况而定)。
从 FBS 文件创建 Java 类
要使用 Flat Buffers,我们现在必须使用 flatc 二进制文件从此".fbs"文件创建所需的类。让我们看看如何做到这一点 −
flatc --java theater.fbs
这将在当前目录的 com > tutorialspoint > theater 文件夹中创建一个 Theater.java 类。我们在应用程序中使用此类的方式与Flat Buffers - Schema一章中的方式类似。
<使用从 fbs 文件创建的 Java 类
首先,让我们创建一个writer来写入theater信息 −
TheaterWriter.java
package com.tutorialspoint.theater; import java.io.FileNotFoundException; import java.io.FileOutputStream; import java.io.IOException; import com.google.flatbuffers.FlatBufferBuilder; public class TheaterWriter { public static void main(String[] args) throws FileNotFoundException, IOException { // 创建一个Flat Buffers构建器 // 它将用于创建Theater FlatBuffer FlatBufferBuilder builder = new FlatBufferBuilder(1024); int totalCapacity = 320; long mobile = 98234567189L; float baseTicketPrice = 22.45f; // 使用 startTheater() 方法创建Theater FlatBuffers Theater.startTheater(builder); // 向Theater FlatBuffer 添加详细信息 Theater.addTotalCapcity(builder, totalCapacity); Theater.addMobile(builder, mobile); Theater.addBaseTicketPrice(builder, baseTicketPrice); // 标记在 Gret FlatBuffer 中输入数据的结束 int theater = Theater.endTheater(builder); // 完成构建器 builder.finish(theater); // 获取要存储的字节 byte[] data = builder.sizedByteArray(); String filename = "theater_flatbuffers_output"; System.out.println("Saving theater to file: " + filename); // 将构建器内容写入名为 theater_flatbuffers_output 的文件 try(FileOutputStream output = new FileOutputStream(filename)){ output.write(data); } System.out.println("Saved theater with following data to disk: " + theater); } }
接下来,我们将有一个阅读器来读取Theater 信息 −
TheaterReader.java
package com.tutorialspoint.theater; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import java.nio.ByteBuffer; public class TheaterReader { public static void main(String[] args) throws FileNotFoundException, IOException { String filename = "theater_flatbuffers_output"; System.out.println("Reading from file " + filename); try(FileInputStream input = new FileInputStream(filename)) { // 获取序列化数据 byte[] data = input.readAllBytes(); ByteBuffer buf = ByteBuffer.wrap(data); // 读取序列化数据中的根对象 Theater theater = Theater.getRootAsTheater(buf); // 打印 theater 剧场值 System.out.println("Total Capacity: " + theater.totalCapcity() + " " + "Mobile: " + theater.mobile() + " " + "Base Ticket Price: " + theater.baseTicketPrice()); } } }
编译项目
现在我们已经设置了reader和writer,让我们编译项目。
mvn clean install
序列化 Java 对象
现在,编译后,让我们先执行writer −
java -cp . arget\flatbuffers-tutorial-1.0.jar com.tutorialspoint.theater.TheaterWriter Saving theater to file: theater_flatbuffers_output Saved theater with following data to disk: 24
反序列化序列化对象
现在,让我们执行读取器来读取同一个文件−
java -cp . arget\flatbuffers-tutorial-1.0.jar com.tutorialspoint.theater.TheaterReader Reading from file theater_flatbuffers_output Total Capacity: 320 Mobile: 98234567189 Base Ticket Price: 22.45
因此,如我们所见,我们可以通过将二进制数据反序列化为 Theater 对象来读取序列化的字符串。现在让我们在下一章 Flat Buffers - bool 中查看 numbers。