JavaWeb---文件读取/IO流

来源:互联网 发布:会发光的自然植物知乎 编辑:程序博客网 时间:2024/06/05 21:39

IO是JAVA中非常重要的一个知识点,对于JAVA开发者而言,学好IO让我们能更加熟悉数据传输之间的原理,同时也能更好的解决数据传输之间造成的乱码问题。

我想大家肯定在使用IO时,遇到各种各样的问题,eg:数据读取失败(读取的内容异常)、获取到的内容乱码、内容读取不全等...

下面我谈谈我自己对IO数据传输的理解:(个人理解,希望对大家有用,有理解错误的地方可以指出一起进步

-------获取文件信息和内容:

**通过File获取到相应的文件信息

**通过FileInputStream获取到指定文件File的文件输入流

------------------如下代码:方法只列出了几个,还有一些大家自己去看文档,很好理解的

File file = new File("/BaiduYunDownload/1.txt");//判断文件是否存在if(file.exists()){System.out.println(file.getName());//获取文件名System.out.println(file.getParent());//获取文件父级路径}
**获取到文件File了我们来创建文件输入流

-------------------代码:

//创建文件输入流FileInputStream is = new FileInputStream(file);//在我们知道文件大小的情况下,可以通过定义一个大小一样的缓冲区byte[] buf = new byte[(int)file.length()];//通过输入流,将文件内容写入定义好的buf缓冲区中is.read(buf);//关闭输入流(虽然系统会通过finalize()在垃圾回收机制中将其关闭,尽量显示的关闭它)is.close();//通过String输出缓冲区内容System.out.println(new String(buf));
这样就可以将文件中的内容打印出来...

-------------------------------------

当然我们也可以通过一个字节数据输出流来接收输入流写入的内容:

**通过ByteArrayOutputStream来将缓冲区内容写入到输出流中,来获取到byte数组

-----------------此方法是最常用的,许多业务都需要获取到的是文件的byte数组,但又不明确文件大小,所以自定义一个固定的大小的缓冲区,用一个输出流来接收并转换成byte数组

----代码如下:

FileInputStream is = new FileInputStream(f);//自定义一个大小为1024字节的缓冲区(1M)byte[] buf = new byte[1024];//定义输入流读取的长度int len=0;//创建字节数组输出流ByteArrayOutputStream bos = new ByteArrayOutputStream();//循环写入,将buf缓冲区内容写入输出流中while((len = is.read(buf))!=-1){System.out.println(len);bos.write(buf, 0, len);}//打印内容(bos.toByteArray()这个是获取到的byte数组)System.out.println(new String(bos.toByteArray(), "UTF-8"));
**其中需要注意的地方:

1.缓冲区定义不要太大,当文件比较大且批量读取的时候会影响读取效率

2.在循环写入的时候,需要定义is.read(buf)写入的缓冲区目标,否则会读取不到数据


-----------------------------下面来讲一下批量读取文件夹中的文件:

-----File类中有方法可以获取到某文件夹下面的所有文件数组

**File[] files = new File("xx.xx").listFiles();

**遍历就可以获取到单个的文件,--但是如果文件夹下面的文件很多,在操作大量文件的时候会影响效率,简单的来说就是File类下面的listFiles()进行遍历操作性能极低,操作少量文件还行,大量的就不行了。

----那么不知道大家知道nio吗(new IO)

---这个是在IO的基础上进行了优化的工具包,通过它来进行大量文件的获取性能就大幅度的提升了。

下面是用nio批量获取文件的代码:

//设置字符集Charset charSet = Charset.forName("UTF-8");//nio获取文件目录下的目录流,其中Path是nio中的文件的path接口//DirectoryStream 是extends了IterableDirectoryStream<Path> ds = Files.newDirectoryStream(new File("/BaiduYunDownload").toPath());//遍历for (Path path : ds) {//获取到文件名System.out.println(path.getFileName());//通过nio的Files中readAllLines方法读取到文件内容并封装到List中List<String> list = Files.readAllLines(path,charSet);//打印内容System.out.println(list);}
希望对大家有用!后续会有文件的上传下载的文章。望大家关注!


0 0
原创粉丝点击