URI与Path的的分析
来源:互联网 发布:雷尼绍测头编程 编辑:程序博客网 时间:2024/05/20 12:21
看到别人的文档有句话一直不能理解于是手动在实践中总结答案
文档是这样说的:
/** * 在某些情况设置URLStreamHandlerFactory的方式不一定会生效. * 在这种情况下,需要用FileSystem来打开一个文件的输入流, * 文件的位置是用Hadoop Path呈现在Hadoop中的,与java.io中的不一样 * */文件位置的呈现怎么就不一样呢?
代码一:
public class URLCat {static{URL.setURLStreamHandlerFactory(new FsUrlStreamHandlerFactory());}/** * IOUtil是个工具类,可以用来在finally从句中关闭流, * 也可以用来拷贝数据到输出流中. * copyByte方法的四个参数代表的含义分别是: * 拷贝的来源,去处,刀背的字节数以及在拷贝完成之后是否关闭流 * */public static void main(String[] args) {InputStream in = null;try {in = new URL(args[0]).openStream();//IOUtils.copyBytes(in, System.out, 4096, false);} catch (IOException e) {IOUtils.closeStream(in);}}}
代码二:
public class FileSystemCat {/** * 在某些情况设置URLStreamHandlerFactory的方式不一定会生效. * 在这种情况下,需要用FileSystem来打开一个文件的输入流, * 文件的位置是用Hadoop Path呈现在Hadoop中的,与java.io中的不一样 * */public static void main(String[] args) throws IOException {String uri = args[0];Configuration conf = new Configuration();FileSystem fs = FileSystem.get(URI.create(uri), conf);InputStream in = null;in = fs.open(new Path(uri));IOUtils.copyBytes(in, System.out, 4090, true);}}
我开始尝试给他们都输入相同的路径: hdfs://localhost:9000/user/admin/test.txt //这个是给main函数设参的路径(怎么设置不用我说了吧)
结果都能运行出来.
然后我又把路径修改了下,/user/admin/test.txt ,这个形式在URI中报错,在Path中却依旧可以运行.这样可以理解成Path自动完成了hadoop的协议.
- URI与Path的的分析
- URI与Path的的分析
- Android的Uri与Path的区别
- 图片uri与path的相互转换
- Uri类使用的理论基础--Uri结构分析与
- 文件File path与content:// Uri的相互转换
- 文件File path与content:// Uri的相互转换
- 【重头学习Android】关于path与URI的转换
- Android File Uri的转换path出错
- 图片Path转换为Uri的方法
- sip URI与sips URI的区别
- sip uri 与sips uri 的区别
- URI与Uri的简单认识
- Android中文件File path与content:// Uri的相互转换
- URL与URI的区别
- URL与URI的区别
- URI与URL的区别
- URL与URI的区别
- c程序中存储空间布局
- 截取视图 保存
- org.xml.sax.SAXParseException: The markup in the document preceding the root element must be well-fo
- 色彩感觉
- sql语句优化
- URI与Path的的分析
- MonoDevelop 调试 Unity3D项目 告别Debug.log()
- QT 2D绘图的坐标系统与图形显示
- c++的float类型包含的最值问题....
- 学习感悟
- js prototype 详解
- unix网络编程初探---获取服务器时间
- What is AOP(Aspect-Oriented Programming)?
- DataTable添加行或者插入行时显示"改行已属于另一表"的解决方案