JavaWeb---文件读取/IO流

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);
		}
希望对大家有用!后续会有文件的上传下载的文章。望大家关注!


  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值