作者热门文章
- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我已经将一个 LibSVM 类型的对象序列化到一个名为 j48.model 的文件中。此文件已传输到 HDFS 文件系统中。
现在,在 hadoop mapreduce 代码中,我如何反序列化该对象并将其读回到 LibSVM 类的实例中?我已经将与 LIBSVM 相关的 .jar 文件作为外部 jar 文件包含到 ma reduce 项目中。
哪些 JAVA 方法可以帮助我将文件 j48.model 的内容读入 LibSVM 对象?
最佳答案
当您打开 HDFS URL 时,它会返回一个 InputStream。
FileSystem fs = FileSystem.get(new Configuration());
InputStream in = fs.open(new Path("your uri"));
您可以将此输入流包装在 ObjectInputStream 中:
ObjectInputStream objReader = new ObjectInputStream(in);
并从中读取你的对象:
LibSVM lib = (LibSVM)objReader.readObject();
关于hadoop - 如何从 Hadoop 中的 HDFS 中的文件读取序列化对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11491542/
我是一名优秀的程序员,十分优秀!