JAVA学习第四十七课 — IO流(一):文件的读写

JAVA学习第四十七课 — IO流(一):文件的读写

大家好,又见面了,我是全栈君。

输入流和输出流相对于内存

将外部设备的数据读取到内存中:输入

将内存中的数据写入外部设备中:输出

IO流经常使用基类

字节流的抽象基类:InputStream,OutputStream

字符的抽象基类:Reader。Writer

PS:由这四个流派生出的子类都是以父类名作为后缀名

如:InputStream的派生类FileInputStream,Reader的派生类FileReader

PS:假设是文字形式的数据应该优先考虑字符流,且将数据从内存写到硬盘上应该是Writer

FileWriter类

演示:将文字储存到硬盘上(FileWriter)

import java.io.FileWriter;
import java.io.IOException;

public class Main 
{
	public static void main(String[] args) throws IOException{
//假设文件不存在。会自己主动创建,存在。会覆盖
		FileWriter fw = new FileWriter("Demo.txt");//抛异常
		
//调用Writer中的write方法,写入数据,但实际上数据写入的是暂时储存缓冲区中
		fw.write("你好");
	
//用flush方法刷新该流的缓冲。

假设该流已保存缓冲区中各种 write() 方法的全部字符,则马上将它们写入预期目标。 fw.flush();//能够用多次//关闭资源//关闭流,关闭资源,在关闭前会先调用flush刷新缓冲中的数据到目的地//API文档:关闭此流,但要先刷新它。

//在关闭该流之后。再调用 write() 或 flush() 将导致抛出 IOException。关闭曾经关闭的流无效。 fw.close();//仅仅能用一次 }}

PS:FileWriter的构造函数 FileWriter(“damo.txt”,true);续写数据,不写,默认是false,会覆盖原有数据

细节

import java.io.FileWriter;
import java.io.IOException;

public class Main 
{
	private static final String LINE_SEPARATOR = System.getProperty("line.separator");
	public static void main(String[] args) throws IOException{

		FileWriter fw = new FileWriter("Demo.txt",true);
		//构造函数,中加个true能够实现对文件的续写

		fw.write("你好"+LINE_SEPARATOR+"世界");//Windows下换行是\r\n,Linus下是\n
		fw.write(LINE_SEPARATOR+"ads");
		fw.flush();
		fw.close();
	}
}

关于流异常的基本处理

在try的外面创建引用。在里面创建对象,关闭时要推断是是否是空指针

import java.io.FileWriter;
import java.io.IOException;

public class Main 
{
	private static final String LINE_SEPARATOR = System.getProperty("line.separator");
	public static void main(String[] args){

		FileWriter fw = null;
		try {
			fw = new FileWriter("z:\\Demo.txt",true);//假设传入一个找不到的地址会抛出两个异常
						//找不到文件异常、空指针异常。所以finally部分。加一句推断是否是空指针
		fw.write("你好"+LINE_SEPARATOR+"世界");
		fw.flush();
		
		} catch (Exception e) {
			System.out.println(e.toString());
		}finally{
			//最后再try一次,单独处理
			if(fw!=null){
				try {
				fw.close();
				} catch (IOException e) {
				throw new RuntimeException("关闭失败");
				}
			}
		}	
	}
}


FileReader类

读取一个文本文件,并将读取出来的数据打印到控制台

import java.io.FileReader;
import java.io.IOException;

public class Main 
{
	public static void main(String[] args) throws IOException {
		
		//一定要确保文件是存在的
		FileReader fr = new FileReader("g:\\java\\Main\\Demo.txt");//文件内容是ab
		
		//read方法,作为整数读取的字符,范围在 0 到 65535 之间 (0x00-0xffff),假设已到达流的末尾,则返回 -1 

//		int c = fr.read();
//		System.out.println((char)c);
//		int c1 = fr.read();
//		System.out.println((char)c1);
//		int c2 = fr.read();
//		System.out.println(c2);//-1
		
		int temp;
		while((temp = fr.read())!=-1){
			System.out.println(temp);
		}
		fr.close();
	}
}

read();读取一个一个字符。相比之下,read()方法还有读取数组的重载形式:效率高

import java.io.FileReader;
import java.io.IOException;

public class Main 
{
	public static void main(String[] args) throws IOException {
		
		FileReader fr = new FileReader("g:\\java\\Main\\Demo.txt");//文件内容是abcdef
		//使用read(char[] a)读取文本文件数据
		/*
		 * 先创建字符数组。 
		 */
//		char ch[] = new char[5];
//		int num = fr.read(ch);//将读取到的字符存储到数组中,num是字符的个数
//		System.out.println(num+":"+new String(ch));//5:abcde
//		
//		int num1 = fr.read(ch);//将读取到的字符存储到数组中
//		System.out.println(num1+":"+new String(ch));//1:fbcde
//		//这里相当于。f把原来数组里的a替换了。而txt里无数据了,所以剩余的数组元素还在
//
//		int num2 = fr.read(ch);//再读也没有数据了。所以返回-1,char数组无覆盖
//		System.out.println(num2+":"+new String(ch));//-1:fbcde
		
		//正规写法
		int num = 0; 
		
		char[] ch = new char[5];//数组的长度最好是1024*n
		
		while((num = fr.read(ch))!=-1){
			System.out.println(new String(ch,0,num));
		}
		
		fr.close();
	}
}


版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/115573.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • cbow模型详解_老C模型

    cbow模型详解_老C模型引言前面我分析了Word2vec的一种模型叫做skip-gram模型。在这篇文章中,我将讲述另一个word2vec模型——连续词袋模型(CBOW)模型。如果你理解skip-gram模型,那么接下来的CBOW模型就更好理解了,因为两者模型互为镜像。我们先来看看CBOW模型与skip-gram模型对比图:如何,这是不是镜像关系?所以接下来的讲解也会和skip-gram那篇文章极其类似。前向传播接

    2025年9月30日
    3
  • 单点登录SSO解决方案之SpringSecurity+JWT实现

    单点登录SSO解决方案之SpringSecurity+JWT实现  通过前面几天文章我们详细的介绍了SpringSecurity的使用,本文我们来看下,结合JWT来实现单点登录操作。一、什么是单点登陆  单点登录(SingleSignOn),简称为SSO,是目前比较流行的企业业务整合的解决方案之一。SSO的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统二、简单的运行机制  单点登录的机制其实是比较简单的,用一个现实中的…

    2022年5月21日
    39
  • 软件测试 黑盒_软件测试黑盒测试报告

    软件测试 黑盒_软件测试黑盒测试报告1、黑盒测试概念      黑盒测试法也称功能测试或数据驱动测试,它是在已知产品所应具有的功能,通过测试来检测每个功能是否都能正常使用,在测试时,把程序看作一个不能打开的黑盒子,在完全不考虑程序内部结构和内部特性的情况下,测试者在程序接口进行测试,它只检查程序功能是否按照需求规格说明书的规定正常使用,程序是否能适当地接收输入数锯而产生正确的输出信息,并且保持外部信息(如数据库或文件)的完整性…

    2022年9月1日
    3
  • xshell ping不通虚拟机_虚拟机为什么ping不通主机

    xshell ping不通虚拟机_虚拟机为什么ping不通主机有朋友联系说:“虚拟机可以ping本机,本机也可以ping虚拟机,但是Xshell连接不上虚拟机。”,找了不少资料发现好像不是这个问题的解决方法,所以在这里介绍下怎么解决这个问题。同时,总结几种xshell连接不上虚拟机的解决方法。

    2022年9月22日
    2
  • Pytest(10)assert断言[通俗易懂]

    Pytest(10)assert断言[通俗易懂]前言断言是写自动化测试基本最重要的一步,一个用例没有断言,就失去了自动化测试的意义了。什么是断言呢?简单来讲就是实际结果和期望结果去对比,符合预期那就测试pass,不符合预期那就测试failed

    2022年8月6日
    4
  • 详解 CAP 定理 Consistency(一致性)、 Availability(可用性)、Partition tolerance(分区容错性)

    详解 CAP 定理 Consistency(一致性)、 Availability(可用性)、Partition tolerance(分区容错性)详解CAP定理Consistency(一致性)、Availability(可用性)、Partitiontolerance(分区容错性)CAP原则又称CAP定理,指的是在一个分布式系统中,Consistency(一致性)、Availability(可用性)、Partitiontolerance(分区容错性),三者不可得兼。分布式系统(distributedsystem)正变得越来越重要,大型网站几乎都是分布式的。分布式系统的最大难点,就是各个节点的状态如何同步。CAP定理是.

    2022年7月25日
    17

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号