学点儿Java_Day12_IO流

2024-03-29 00:36
文章标签 java io day12 点儿

本文主要是介绍学点儿Java_Day12_IO流,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1 IO介绍以及分类

IO: Input Output
流是一组有顺序的,有起点和终点的字节集合,是对数据传输的总称或抽象。即数据在两设备间的传输称为流,流的本质是数据传输,根据数据传输特性将流抽象为各种类,方便更直观的进行数据操作

1.1 IO流的分类

1. 根据处理的数据类型不同可以分为:字符流和字节流。
2. 根据数据的流向不同可以分为:输入流和输出流。
在这里插入图片描述
在这里插入图片描述

1.2 字节流(Byte Stream)

1.字节流以字节为单位进行读取和写入操作,适合处理二进制数据(如图片、视频、音频等)或者文本文件。
2.字节流类通常以 InputStream 和 OutputStream 结尾,例如 FileInputStream、FileOutputStream。
3.字节流可以用于读写任何类型的文件,但对于文本文件的处理可能需要做字符编码转换。

1.3 字符流(Character Stream)

1.字符流以字符为单位进行读取和写入操作,适合处理文本数据字符流会自动处理字符编码转换,避免了字节流在处理文本时可能出现的乱码问题。
2.字符流类通常以 Reader 和 Writer 结尾,例如 FileReader、FileWriter。
3.字符流适合处理文本文件,能够更方便地读写文本中的字符数据。

1.4 选择建议

1.如果你需要处理文本文件,推荐使用字符流,因为它们能够更好地处理字符编码和文本数据。
2.如果需要处理二进制文件或者未经处理的数据,应该使用字节流。

2 字符流

    @Testpublic void test1() {FileReader fileReader = null;//声明放在外边  局部变量必须初始化//FileReader fileReader;//声明放在外边 ×××××try {fileReader = new FileReader("io.txt");//打开水龙头//Reads a single character.int ch1 = fileReader.read();System.out.println((char)ch1);//aint ch2 = fileReader.read();System.out.println((char)ch2);//bint ch3 = fileReader.read();System.out.println((char)ch3);//cint ch4 = fileReader.read();System.out.println((char)ch4);//System.out.println(ch4);//-1} catch (FileNotFoundException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();} finally {//在finally里边必须关闭IO流try {fileReader.close();} catch (IOException e) {throw new RuntimeException(e);}}}@Testpublic void test2() {try {FileReader fileReader = new FileReader("io.txt");int ch = -1;while ((ch = fileReader.read()) != -1) {System.out.println((char)ch);}} catch (FileNotFoundException e) {throw new RuntimeException(e);} catch (IOException e) {throw new RuntimeException(e);}}//----------Day12---------------@Testpublic void test3() {try {FileReader fileReader = new FileReader("io.txt");char[] buffer = new char[10];int length = -1;//public int read(char[] cbuf)//一次将10个字符读入到buffer数组里面//返回:读取的字符数,如果已经达到流的末尾,返回-1while ((length = fileReader.read(buffer)) != -1) {System.out.println(length);System.out.println(buffer);}} catch (FileNotFoundException e) {throw new RuntimeException(e);} catch (IOException e) {throw new RuntimeException(e);}}@Testpublic void test4() {//父类FileReader fileReader = null;FileWriter fileWriter = null;try {fileReader = new FileReader("io.txt");fileWriter = new FileWriter("io_back.txt");char[] buffer = new char[10];int length = -1;//public int read(char[] cbuf)//一次将10个字符读入到buffer数组里面//返回:读取的字符数,如果已经达到流的末尾,返回-1while ((length = fileReader.read(buffer)) != -1) {System.out.println(length);System.out.println(buffer);//读出多少写多少,最后一次读出来的数据很有可能不够buffer数组的长度fileWriter.write(buffer, 0, length);}} catch (FileNotFoundException e) {throw new RuntimeException(e);} catch (IOException e) {throw new RuntimeException(e);} finally {//先打开的后关闭if (fileWriter != null) {try {fileWriter.close();} catch (IOException e) {throw new RuntimeException(e);}}if (fileReader != null) {try {fileReader.close();} catch (IOException e) {throw new RuntimeException(e);}}}}

3 字节流

在这里插入图片描述

    @Testpublic void test5() {//FileInoutSteam 父类是InputSteamFileInputStream fileInputStream = null;//经验 先生命成null 局部变量必须初始化FileOutputStream fileOutputStream = null;try {fileInputStream = new FileInputStream("baidu.png");fileOutputStream = new FileOutputStream("baidu_back.png");byte[] buffer = new byte[1024];int length = -1;while ((length = fileInputStream.read(buffer)) != -1){//赋值语句有结果 结果就是length值System.out.println(length);//fileOutputStream.write(buffer, 0, length);//这个不会多写fileOutputStream.write(buffer);//会多写几个字节}} catch (FileNotFoundException e) {throw new RuntimeException(e);} catch (IOException e) {throw new RuntimeException(e);} finally {if (fileOutputStream != null) {try {fileOutputStream.close();} catch (IOException e) {throw new RuntimeException(e);}}if (fileInputStream != null) {try {fileInputStream.close();} catch (IOException e) {throw new RuntimeException(e);}}}}

在这里插入图片描述
在这里插入图片描述

4 对象流

ObjectInputStream、ObjectOutputStream
将对象写入文件的操作流ObjectOutputStream,称为序列化。
从流中读取对象的操作流程ObjectInputStream,称为反序列化。
java.io.NotSerializableException: com.situ.day13.Student
Serialize:序列化

/** 适度编码益脑,沉迷编码伤身,合理安排时间,享受快乐生活。* Copyright @TangXJ* Created by TangXJ* Created&Used date: 2024/3/27 下午2:06 ~ 2024/3/27 下午3:39* Modified date: 2024/3/27 下午3:39*/package com.sdust.day12;import org.junit.Test;import java.io.*;public class Student implements Serializable {//实现一个接口private Integer id;private String name;private Integer age;private String gender;public Student() {}public Student(Integer id, String name, Integer age, String gender) {this.id = id;this.name = name;this.age = age;this.gender = gender;}public Integer getId() {return id;}public void setId(Integer id) {this.id = id;}public String getName() {return name;}public void setName(String name) {this.name = name;}public Integer getAge() {return age;}public void setAge(Integer age) {this.age = age;}public String getGender() {return gender;}public void setGender(String gender) {this.gender = gender;}@Overridepublic String toString() {return "Student{" +"id=" + id +", name='" + name + '\'' +", age=" + age +", gender='" + gender + '\'' +'}';}//对象流@Testpublic void test1() {Student student = new Student();student.setId(1);student.setName("zhangsan");student.setAge(23);student.setGender("男");//java.lang.RuntimeException: java.io.NotSerializableException: com.sdust.day12.Student//不能序列化的异常//实现一个接口ObjectOutputStream objectOutputStream = null;//不负责写文件 对象转换交给它ObjectOutputStream来完成//负责把一个对象 做一个转换FileOutputStream fileOutputStream = null;try {fileOutputStream = new FileOutputStream("stu");objectOutputStream = new ObjectOutputStream(fileOutputStream);objectOutputStream.writeObject(student);} catch (FileNotFoundException e) {throw new RuntimeException(e);} catch (IOException e) {throw new RuntimeException(e);} finally {//x先打开的后关闭if (objectOutputStream != null){try {objectOutputStream.close();} catch (IOException e) {throw new RuntimeException(e);}}if (fileOutputStream != null) {try {fileOutputStream.close();} catch (IOException e) {throw new RuntimeException(e);}}}}@Testpublic void test2() {ObjectInputStream objectInputStream = null;FileInputStream fileInputStream = null;try {fileInputStream = new FileInputStream("stu");objectInputStream = new ObjectInputStream(fileInputStream);//Student student = objectInput.readObject();//报错 父类不能转换为子类//Object object = new Student();Student student = (Student) objectInputStream.readObject();System.out.println(student);} catch (FileNotFoundException e) {throw new RuntimeException(e);} catch (IOException e) {throw new RuntimeException(e);} catch (ClassNotFoundException e) {throw new RuntimeException(e);} finally {if (objectInputStream != null) {try {objectInputStream.close();} catch (IOException e) {throw new RuntimeException(e);}}if (fileInputStream != null) {try {fileInputStream.close();} catch (IOException e) {throw new RuntimeException(e);}}}}
}

这个Demo运行时要注释掉所有构造函数。
一般情况下:先打开的后关闭,后打开的先关闭。
另一种情况:看依赖关系,如果流A依赖于流B,先关闭流A,再关闭流B。

这篇关于学点儿Java_Day12_IO流的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/857132

相关文章

在Ubuntu上部署SpringBoot应用的操作步骤

《在Ubuntu上部署SpringBoot应用的操作步骤》随着云计算和容器化技术的普及,Linux服务器已成为部署Web应用程序的主流平台之一,Java作为一种跨平台的编程语言,具有广泛的应用场景,本... 目录一、部署准备二、安装 Java 环境1. 安装 JDK2. 验证 Java 安装三、安装 mys

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

SpringCloud集成AlloyDB的示例代码

《SpringCloud集成AlloyDB的示例代码》AlloyDB是GoogleCloud提供的一种高度可扩展、强性能的关系型数据库服务,它兼容PostgreSQL,并提供了更快的查询性能... 目录1.AlloyDBjavascript是什么?AlloyDB 的工作原理2.搭建测试环境3.代码工程1.

Java调用Python代码的几种方法小结

《Java调用Python代码的几种方法小结》Python语言有丰富的系统管理、数据处理、统计类软件包,因此从java应用中调用Python代码的需求很常见、实用,本文介绍几种方法从java调用Pyt... 目录引言Java core使用ProcessBuilder使用Java脚本引擎总结引言python

SpringBoot操作spark处理hdfs文件的操作方法

《SpringBoot操作spark处理hdfs文件的操作方法》本文介绍了如何使用SpringBoot操作Spark处理HDFS文件,包括导入依赖、配置Spark信息、编写Controller和Ser... 目录SpringBoot操作spark处理hdfs文件1、导入依赖2、配置spark信息3、cont

springboot整合 xxl-job及使用步骤

《springboot整合xxl-job及使用步骤》XXL-JOB是一个分布式任务调度平台,用于解决分布式系统中的任务调度和管理问题,文章详细介绍了XXL-JOB的架构,包括调度中心、执行器和Web... 目录一、xxl-job是什么二、使用步骤1. 下载并运行管理端代码2. 访问管理页面,确认是否启动成功

Java中的密码加密方式

《Java中的密码加密方式》文章介绍了Java中使用MD5算法对密码进行加密的方法,以及如何通过加盐和多重加密来提高密码的安全性,MD5是一种不可逆的哈希算法,适合用于存储密码,因为其输出的摘要长度固... 目录Java的密码加密方式密码加密一般的应用方式是总结Java的密码加密方式密码加密【这里采用的

Java中ArrayList的8种浅拷贝方式示例代码

《Java中ArrayList的8种浅拷贝方式示例代码》:本文主要介绍Java中ArrayList的8种浅拷贝方式的相关资料,讲解了Java中ArrayList的浅拷贝概念,并详细分享了八种实现浅... 目录引言什么是浅拷贝?ArrayList 浅拷贝的重要性方法一:使用构造函数方法二:使用 addAll(

解决mybatis-plus-boot-starter与mybatis-spring-boot-starter的错误问题

《解决mybatis-plus-boot-starter与mybatis-spring-boot-starter的错误问题》本文主要讲述了在使用MyBatis和MyBatis-Plus时遇到的绑定异常... 目录myBATis-plus-boot-starpythonter与mybatis-spring-b