24/04/11总结

IO流(First edition):

IO流:用于读入写出文件中的数据
流的方向(输入指拿出来,输出指写进去)
输入流:读取
输出流:写出
操作文件类型
字节流:所有类型文件
字符流:纯文本

 

字节流:
InputStream的子类:FileInputStream:操作本地文件的字节输入流
OutputStream的子类:FileOutputStream:操作本地文件的字节输出流
 
 //1.创建字节输出流对象
                    //细节1:参数是字符串表示的路径或者是File对象都是可以的
                    //细节2:如果文件不存在会创建一个新的文件,但是要保证父级路径是存在的。
                    //细节3:如果文件存在,会清空文件的内容
        FileOutputStream fos = new FileOutputStream("C:\\Users\\35303\\Desktop\\a.txt");
 //2.写入
                    //细节:write方法的参数是整数,但是实际上写到本地文件中的是整数在ASCII上对应的字符
        //fos.write(67);
            //3.释放资源
        //fos.close();
FileOutputStream写数据的3种方式
方法名称                                              说明
void write(int b)                                     一次写一个字节数据
void write(byte[]b)                                   一次写一个字节数组数据
void write(byte[lb,int off,int len) (参数1:数组,参数2:起始索引,参数3:个数)  一次写一个字节数组的部分数据
 //void write(byte[]b)
       byte a[] = new byte[]{97,98,99,100,101};
        fos.write(a);
        //fos.close();

        //void write(byte[lb,int off,int len)
        byte b[] = new byte[]{65,66,67,68,69};
        fos.write(b,1,3);   //从1号索引写三个
        fos.close();
 //续写:在打开时后面写个true
        FileOutputStream fos1 = new FileOutputStream("C:\\Users\\35303\\Desktop\\b.txt",true);
        //方便转字符
        String s = "djaofjawsfja";
        byte[] bytes = s.getBytes();
        fos1.write(bytes);
        //fos1.close();

        //换行: \r\n(单写\r或\n也可以)
        String s1 ="\r\n";
        String s2 = "666";
        byte[] bytes1 = s1.getBytes();
        byte[] bytes2 = s2.getBytes();
        fos1.write(bytes1);
        fos1.write(bytes2);
        fos1.close();
FileInputStream:
//FileInputStream

        //1.创建对象
        FileInputStream fis = new FileInputStream("C:\\Users\\35303\\Desktop\\b.txt");
        //2.读取数据(如果没数据了read会返回-1)
        //read:表示读取数据,而且是读取一个数据就移动一次指针
        int a1 = fis.read();
        System.out.println((char)a1);
        //3.释放资源
        //fis.close();

        //字节输入流循环读取
        int a2;
        while((a2=fis.read())!=-1){
            System.out.print((char)a2);
        }
        fis.close();


        //方法名称                                                                  说明
        //public int read()                                                 一次读一个字节数据
        //public int read(byte[] buffer)  (返回值为获取的长度)              一次读一个字节数组数据
字符流:字符流的底层其实就是字节流
  //字符流=字节流+字符集
特点:
输入流:一次读一个字节,遇到中文时,一次读多个字节
输出流:底层会把数据按照指定的编码方式进行编码,变成字节再写到文件中
Reader的子类:FileReader
Writer的子类:FileWriter

FileReader:
构造方法 (1.创建字符输入流对象)                                                 说明
public FileReader(File file)                             创建字符输入流关联本地文件
public FileReader(string pathname)                       创建字符输入流关联本地文件
细节1:如果文件不存在就直接报错
2.读取数据
成员方法                              说明
public int read()                     读取数据,读到末尾返回-1
public int read(char[] buffer)        读取多个数据,读到末尾返回-1
细节1:按字节进行读取遇到中文,一次读多个字节,读取后解码,返回一个整数
细节2:读到文件末尾了,read方法返回-1。
3.释放资源
close();

//read无参
        //1.创建对象并关联本地文件
        FileReader fr = new FileReader("C:\\Users\\35303\\Desktop\\b.txt");
        //2.读取数据
        //字符流的底层也是字节流,默认也是一个字节一个字节的读取的。
        //如果遇到中文就会一次读取多个,GBK一次读两个字节,UTF-8一次读三个字节(IDEA默认UTF-8)
        int ch;
        while((ch=fr.read())!=-1){          //空参是传出的ch是字符的二进制
            System.out.print((char)ch);
        }
        System.out.println();
read()细节:
1.read():默认也是一个字节一个字节的读取的,如果遇到中文就会一次读取多个
2.在读取之后,方法的底层还会进行解码并转成十进制。
最终把这个十进制作为返回值
这个十进制的数据也表示在字符集上的数字
英文:文件里面二进制数据 0110 0001
read方法进行读取,解码并转成十进制97
中文:文件里面的二进制数据 11100110 10110001 10001001
read方法进行读取,解码并转成十进制27721
// 我想看到中文汉字,就是把这些十进制数据,再进行强转就可以了
  //read有参
        //1.创建对象
        FileReader fr1 = new FileReader("C:\\Users\\35303\\Desktop\\b.txt");
        //2.读取数据
        char []chars = new char[2]; //表示一次读两个数据
        int len;
        while((len=fr1.read(chars))!=-1){           //有参时传出来的是长度
            //把数组中的数据变成字符串再去打印
            System.out.print(new String(chars,0,len));        //读几个就转几个
        }
        //3.释放资源
        fr1.close();

 

FileWriter:
构造方法                                                                   说明
public FileWriter(File file)                                              创建字符输出流关联本地文件
public FileWriter(String pathname)                                        创建字符输出流关联本地文件
public FileWriter(File file,boolean append)  (append:续写开关,为true是续写) 创建字符输出流关联本地文件,续写
public FileWriter(String pathname,boolean append)                         创建字符输出流关联本地文件,续写
成员方法                                                      说明
void write(int c)                                             写出一个字符
void write(string str)                                        写出一个字符串
void write(String str,int off,int len)                        写出一个字符串的一部分
void write(char[] cbuf)                                       写出一个字符数组
void write(char[] cbuf,int off,int len)                       写出字符数组的一部分
FileWriter书写细节
1.创建字符输出流对象
  //细节1:参数是字符串表示的路径或者File对象都是可以的
  //细节2:如果文件不存在会创建一个新的文件,但是要保证父级路径是存在的
  //细节3:如果文件已经存在,则会清空文件,如果不想清空可以打开续写开关
2.写数据
细节: 如果write方法的参数是整数,但是实际上写到本地文件中的是整数在字符集上对应的字符
3.释放资源
细节:每次使用完流之后都要释放资源

 

 //方法write(int c)       写出一个字符
        FileWriter fw = new FileWriter("C:\\Users\\35303\\Desktop\\b.txt",true);
        fw.write(25105);//(25105:我)//根据字符集的编码方式进行编码,把编码之后的数据写到文件中去
        //fw.close();

        //方法FileWriter(String pathname)       写出一个字符串
        fw.write("\n你好hello位");
        fw.close();
       //write(String str,int off,int len)    写出一个字符串的一部分
        //fw.write("\n你好hello位",0,3);

        //方法void write(char[] cbuf)          写出一个字符数组
        //char s[]= new char[]{'a','b','c'};
        //fw.write(char);
        //fw.close();

 

前面学的都是基本流,下面的是高级流
缓冲流:BufferedInputStream(字节缓存输入流)、BufferedOutputStream(字节缓存输出流)
BufferedReader(字符缓存输入流)、BufferedWriter(字符缓冲输出流)
字节缓存流原理:底层自带了长度为8192的缓冲区提高性能
方法名称                                                      说明
public BufferedInputStream(InputStream is)        把基本流包装成高级流,提高读取数据的性能
public BufferedOutputStream(OutputStream os)       把基本流包装成高级流,提高写出数据的性能
//字节缓冲流
        //一次操作一个字节
        //1.创建缓冲流的对象
        BufferedInputStream bis = new BufferedInputStream(new FileInputStream("C:\\Users\\35303\\Desktop\\b.txt"));
        BufferedOutputStream bos = new BufferedOutputStream(new FileOutputStream("C:\\Users\\35303\\Desktop\\c.txt"));
        //2.循环读取并写到目的地
        int b;
        while((b=bis.read())!=-1){
            bos.write((char)b);
        }
        //3.释放资源
        bos.close();
        bis.close();

 

 //一次操作多个字节
            byte [] bytes = new byte[1024];
            int len;
            while((len=bis.read(bytes))!=-1){
                bos.write(bytes,0,len);
            }
        bos.close();
        bis.close();
字符缓存流原理:底层自带了长度为8192的缓冲区提高性能
方法名称                                      说明
public BufferedReader(Reader r)               把基本流变成高级流
public BufferedWriter(Writer r)               把基本流变成高级流
字符缓冲流特有方法
字符缓冲输入流特有方法                                       说明
public String readLine()                  读取一行数据,如果没有数据可读了,会返回null
字符缓冲输出流特有方法                                       说明
public void newLine()                                   跨平台的换行
//1.创建字符缓冲输入流的对象
        BufferedReader br = new BufferedReader(new FileReader("C:\\Users\\35303\\Desktop\\b.txt"));
        //2.读取数据
        String line;
        while ((line=(br.readLine()))!=null) {      //获取文件中一行的数据
            System.out.println(line);
        }
        //3.释放资源
        br.close();

        //1.创建字符缓冲输出流对象
        BufferedWriter bw = new BufferedWriter(new FileWriter("C:\\Users\\35303\\Desktop\\c.txt",true));
        //2.写出数据
        bw.write("你嘴角上扬的样子");
        bw.newLine();                        //因为不同平台的换行不一样,所以可以用跨平台换行newLine
        bw.write("hello world");
        //3.释放资源
        bw.close();
转换流(不需要掌握,看看懂懂意思)
转换流属于字符流
InputStreamReader(转换输入流),OutputStreamWriter(转换输出流)
转换流是字符流和字节流之间的桥梁
输入时把字节流转换成字符流,然后就拥有了字符流的特性,输出又转换为字节流
作用:字节流想使用字符流中的方法了那就可以使用转换流转一下
 //1.创建对象并指定字符编码
        InputStreamReader isr = new InputStreamReader(new FileInputStream("C:\\Users\\35303\\Desktop\\b.txt"),"GBK");
        //第二个参数不写默认UTF-8,写了就是转换为什么编码
        //2.读取数据
        int ch;
        while((ch=isr.read())!=-1){
            System.out.print((char)ch);
        }
        //3.释放资源
        isr.close();

        //1.创建转换流的对象
        OutputStreamWriter osw = new OutputStreamWriter(new FileOutputStream("C:\\Users\\35303\\Desktop\\b.txt"),"GBK");
        //2.写出数据
        osw.write("nihao");
        //3.释放资源
        osw.close();

 

序列化流(又叫对象操作输出流):可以把java中的对象写到本地文件中
序列化流属于字节流(输出outputStream),反序列化流(输入inputStream)
ObjectInputStream(反序列化流),ObjectOutputStream(序列化流)
构造方法                                                          说明
public ObjectOutputStream(OutputStream out)               把基本流包装成高级流
成员方法                                                            说明
public final void writeObject(object obi)                 把对象序列化(写出)到文件中去
需求:利用序列化流/对象操作输出流,把一个对象写到本地文件中
序列化流的小细节
使用对象输出流将对象保存到文件时会出现NotSerializableException异常
解决方案:
需要让Javabean类实现Serializable接口
 //1.创建对象
        Demo10two stu = new Demo10two("张三",12,"da");

        //2.创建序列化流的对象
        ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("C:\\Users\\35303\\Desktop\\d.txt"));

        //3.写出数据
        oos.writeObject(stu);

        //4.释放资源
        oos.close();

 

反序列化流(又叫对象操作输入流)
可以把序列化到本地文件中的对象,读取到程序中来
构造方法                                                  说明
public ObjectInputStream(InputStream out)         把基本流变成高级流
成员方法                                                              说明
public object readObject()                        把序列化到本地文件中的对象,读取到程序中来
//1.创建反序列化流的对象
        ObjectInputStream ois = new ObjectInputStream(new FileInputStream("C:\\Users\\35303\\Desktop\\d.txt"));

        //2.读取数据
        Object o = ois.readObject();

        //3.打印对象
        System.out.println(o);

        //3.释放资源
        ois.close();

 javabean类:
 

package com.itheima.demo14IO流;

import java.io.Serializable;

public class Demo10two implements Serializable {

    private static final long serialVersionUID = -8462176507494611942L;
    //反序列化流要定义版本号,在IDEA里设置了,所以只要点黄色的那段类名然后alt+回车添加版本号就行了

    //序列化流的小细节
    //使用对象输出流将对象保存到文件时会出现NotSerializableException异常
    //解决方案:
    //需要让Javabean类实现Serializable接口

    //Serializable接口里面是没有抽象方法,标记型接
    //一旦实现了这个接口,那么就表示当前的student类可以被序列化

    private  String name;
    private  int age;
    //transient:瞬态关键字
    //作用:不会把当前属性序列化到本地文件当中
    private transient String a;

    public Demo10two(String dawda, int age, String da) {
    }

    public Demo10two(long serialVersionUID, String name, int age, String a) {
        this.name = name;
        this.age = age;
        this.a = a;
    }

    /**
     * 获取
     * @return name
     */
    public String getName() {
        return name;
    }

    /**
     * 设置
     * @param name
     */
    public void setName(String name) {
        this.name = name;
    }

    /**
     * 获取
     * @return age
     */
    public int getAge() {
        return age;
    }

    /**
     * 设置
     * @param age
     */
    public void setAge(int age) {
        this.age = age;
    }

    /**
     * 获取
     * @return a
     */
    public String getA() {
        return a;
    }

    /**
     * 设置
     * @param a
     */
    public void setA(String a) {
        this.a = a;
    }

    public String toString() {
        return "Demo10two{name = " + name + ", age = " + age + ", a = " + a + "}";
    }






}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/535532.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

工作流引擎常见API(以camunda为例)

在Camunda中,API的继承关系主要体现在各个服务接口之间。以下是Camunda中一些常见服务接口的继承关系: ProcessEngineServices 接口: RepositoryService: 负责管理流程定义和部署。RuntimeService: 负责管理流程实例的…

2023年通用人工智能AGI等级保护白皮书

今天分享的是人工智能专题系列深度研究报告:《人工智能专题:2023年通用人工智能AGI等级保护白皮书》。 通用人工智能发展现状 本章主要介绍通用人工智能的基本情况,包括其发展历史、现状以及组成架构等内容。本文还将通过从技术角度出发来分…

PTA 应急救援站选址(floyd+打印路径)

大学城虎溪社区有很多居民小区,居民小区道路图是连通的。现要在该社区新建一个应急救援站,且该应急救援站要和某个小区建在一起。为了使应急救援最快速,经各部门商量决定:应急救援站建好后,离应急救援站最远的小区到应…

大话设计模式之命令模式

命令模式是一种行为型设计模式,它将请求或操作封装成一个对象,从而允许客户端参数化操作。这意味着客户端将一个请求封装为一个对象,这样可以将请求的参数化、队列化和记录日志,以及支持可撤销的操作。 命令模式主要由以下几个角…

kaggle 泰坦尼克号1(根据男女性存活率)

kaggle竞赛 泰坦尼克号 流程 下载kaggle数据集导入所要使用的包引入kaggle的数据集csv文件查看数据集的大小和长度去除冗余数据建立特征工程导出结果csv文件 1.下载kaggle数据集 2.导入所要使用的包 import pandas as pd import numpy as np import matplotlib.pyplot as …

leetcode328.奇偶链表

1. 题目描述 在线练习 2. 解题思路 这道题,官方给的是中等难度。其实是一道基础题,大家应该都可以写得出来。 题目中给的示例可以清楚的看到,合并前后的奇偶链的各自包含的节点的顺序是不变的,我们基本可以确定使用尾插法来合并…

Ansys Mechanical | 软件介绍:业界一流的有限元求解器

Ansys Mechanical 有限元分析软件 Ansys Mechanical 是业界一流的有限元求解器,具有结构、热学、声学、瞬态和非线性功能,可帮助改进建模。 ​ 软件概览 Ansys Mechanical 创建了一个使用有限元仿真分析软件(FEA)进行结构分析…

猝不及防 CCF-B ICPP 2024投稿延期至4月22日提交摘要 机会来了别错过

会议之眼 快讯 第53届ICPP(International Conference on Parallel Processing)即国际并行处理会议将于 2024年 8月12日-15日在瑞典哥特兰岛举行!ICPP是世界上最古老的连续举办的并行计算计算机科学会议之一。它是学术界、工业界和政府的研究…

欢迎加入PenPad Season 2 ,获得勋章以及海量 Scroll 生态权益

PenPad 是 Scroll 生态中的首个 LaunchPad 平台,该平台继承了 Scroll 生态的技术优势,具备包括隐私在内的系列特点,同时且也被认为是 Scroll 生态最重要的价值入口之一。Penpad 与 Scroll 官方始终保持着合作,同时该项目自启动以来…

你一定不能错过的多模态大模型!阿里千问开源Qwen-VL!具备图文解读等能力

1. Qwen-VL简介 1.1. 介绍 Qwen-VL的多语言视觉语言模型系列,基于Qwen-7B语言模型。该模型通过视觉编码器和位置感知的视觉语言适配器,赋予语言模型视觉理解能力。 Qwen-VL采用了三阶段的训练流程,并在多个视觉语言理解基准测试中取得了领先的成绩。该模型支持多语言、多图…

办公室电脑监控软件哪个最好用

办公室电脑监控软件哪个最好用 办公室监控软件主要用于帮助企业管理员监控员工在工作时间内的电脑使用情况,以提高工作效率、保障数据安全、遵守合规要求和维护良好的工作秩序。以下是一些推荐的办公室监控软件。 1、安企神 (1) 强大的监控功能:域智盾…

【文献分享】机器学习 + 分子动力学(LAMMPS 输入文件)+ 第一性原理 + 热学性质 + 动力学性质

分享一篇关于机器学习 分子动力学 第一性原理 热学性质 动力学性质的文章。 感谢论文的原作者! 关键词: 1. Machine learning, 2. Deep potential, 3. Molecular dynamics 4. Molten salts 5. Thermophysical properties 6. Phase diagram 主…

并查集加训

1.模板 #include<iostream> using namespace std; const int N 1e4 10; int p[N]; int n, m;int fd(int x){if(x ! p[x]){p[x] fd(p[x]);}return p[x]; }int main(){scanf("%d%d", &n, &m);for(int i 1; i < n; i){p[i] i;}int z, x, y;while(…

nvm更新node版本

1、nvm安装和管理多个 Node.js 版本&#xff1a;NVM 允许用户在计算机上同时安装多个不同版本的 Node.js。这使得开发人员可以轻松地在不同的项目中使用不同的 Node.js 版本&#xff0c;而无需手动安装或卸载。 2、nvm切换 Node.js 版本&#xff1a;通过 NVM&#xff0c;用户可…

一辆新能源汽车需要多少颗传感器?

随着科技的发展和环保意识的日益提高&#xff0c;新能源汽车&#xff08;包括纯电动汽车、混合动力汽车等&#xff09;在全球范围内越来越受到欢迎。这些汽车不仅减少了碳排放&#xff0c;还推动了汽车产业的创新。然而&#xff0c;这些高科技汽车的背后&#xff0c;隐藏着许多…

git lfs 大文件管理

简介 git-lfs 是 Git Large File Storage 的缩写&#xff0c;是 Git 的一个扩展&#xff0c;用于处理大文件的版本控制。 它允许你有效地管理和存储大型二进制文件&#xff0c;而不会使 Git 仓库变得过大和不稳定。以下是一些与 git-lfs 相关的常见命令和解释&#xff1a; 常…

zabbix“专家坐诊”第236期问答

问题一 Q&#xff1a;我的trap里已经可以收到信息了&#xff0c;后续要怎么创建监控项呀&#xff1f; A&#xff1a;参考&#xff1a; 问题二 Q&#xff1a;snmp和snmp trap咋搞&#xff1f; A&#xff1a;你指的是如何开启这些协议还是如何做监控项&#xff1f; Q&#xff1…

KVM部署

1、检查虚拟化支持 首先&#xff0c;确认你的系统处理器支持硬件虚拟化&#xff0c;在Linux终端中&#xff0c;使用以下命令&#xff1a; egrep -c (vmx|svm) /proc/cpuinfo2、安装KVM及其工具 yum update yum install qemu-kvm libvirt libvirt-python libguestfs-tools vi…

[大模型]基于 ChatGLM3 和 LangChain 搭建知识库助手

基于 ChatGLM3 和 LangChain 搭建知识库助手 环境配置 在已完成 ChatGLM3 的部署基础上&#xff0c;还需要安装以下依赖包&#xff1a; pip install langchain0.0.292 pip install gradio4.4.0 pip install chromadb0.4.15 pip install sentence-transformers2.2.2 pip inst…

主从数据同步原理

2.2.主从数据同步原理 2.2.1.全量同步 主从第一次建立连接时&#xff0c;会执行全量同步&#xff0c;将master节点的所有数据都拷贝给slave节点&#xff0c;流程&#xff1a; 这里有一个问题&#xff0c;master如何得知salve是第一次来连接呢&#xff1f;&#xff1f; 有几个…