Avro中DatumWriter的用途是什么?

Maj*_*imi 4 java avro

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();
Run Code Online (Sandbox Code Playgroud)

目的是DatumWriter<User>什么?我的意思是它提供了什么?它提供write方法,但我们使用而不是使用它DataFileWriter.有人可以解释它的设计目的吗?

ben*_*nyl 7

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

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