4

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. 有人可以解释它的设计目的吗?

4

1 回答 1

7

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

鉴于此记录,DataFileWriter 负责将其写入文件。

于 2014-12-22T18:53:34.850 回答