Avro网站有一个示例:

DatumWriter<User> userDatumWriter = new SpecificDatumWriter<User>(User.class);
DataFileWriter<User> dataFileWriter = new DataFileWriter<User>(userDatumWriter);
dataFileWriter.create(user1.getSchema(), new File("users.avro"));
dataFileWriter.append(user1);
dataFileWriter.append(user2);
dataFileWriter.append(user3);
dataFileWriter.close();
DatumWriter<User>的作用是什么?我的意思是它提供了什么?它提供了write方法,但是我们没有使用它,而是使用DataFileWriter。有人可以解释它的设计目的吗?

最佳答案

DatumWriter类负责将给定的数据对象转换为具有给定架构的avro记录(在您的情况下是从User类中提取的)。

给定此记录,DataFileWriter负责将其写入文件。

10-04 19:10