关闭

[置顶] JavaWeb---文件读取/IO流

标签: javaIO
322人阅读 评论(0) 收藏 举报
分类:

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了Iterable
		DirectoryStream<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

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:44827次
    • 积分:1033
    • 等级:
    • 排名:千里之外
    • 原创:52篇
    • 转载:27篇
    • 译文:0篇
    • 评论:21条
    最新评论