java -- 缓冲流、转换流、序列化流

这篇具有很好参考价值的文章主要介绍了java -- 缓冲流、转换流、序列化流。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

缓冲流

缓冲流, 也叫高效流, 按照数据类型分类:

  • 字节缓冲流BufferedInputStreamBufferedOutputStream
  • 字符缓冲流BufferedReaderBufferedWriter

缓冲流的基本原理,是在创建流对象时,会创建一个内置的默认大小的缓冲区数组,通过缓冲区读写,减少系统IO次数,从而提高读写的效率。

字节缓冲流

// 构造方法
public BufferedInputStream(InputStream in)
// 创建一个 新的缓冲输入流
public BufferedOutputStream(OutputStream out)
// 创建一个新的缓冲输出流。
// 字节输出缓冲流
OutputStream out = new BufferedOutputStream(new FileOutputStream("FileAndIoStream\\test\\4.txt"));

out.write("hello world\r\n".getBytes());
out.write("hello world\r\n".getBytes());
out.write("hello world\r\n".getBytes());
out.write("hello world\r\n".getBytes());
out.close();

// 字节输入缓冲流
InputStream in = new BufferedInputStream(new FileInputStream("FileAndIoStream\\test\\4.txt"));
byte[] chs = new byte[1024];
int len = 0;
while ((len = in.read(chs)) != -1) {
    System.out.println(new String(chs, 0, len));
}
in.close();

字符缓冲流

// 构造方法
public BufferedReader(Reader in)
// 创建一个 新的缓冲输入流
public BufferedWriter(Writer out)
// 创建一个新的缓冲输出流。

特有方法

  • BufferedReader:public String readLine(): 读一行文字。
  • BufferedWriter:public void newLine(): 写一行行分隔符,由系统属性定义符号。
BufferedReader bufferedReader = new BufferedReader(new FileReader("FileAndIoStream\\test\\4.txt"));
String line = null;
while ((line = bufferedReader.readLine()) != null) {
    System.out.println(line);
}
bufferedReader.close();

BufferedWriter bw = new BufferedWriter(new FileWriter("FileAndIoStream\\test\\4.txt"));
bw.write("你好");
bw.close();

文本排序练习

3.侍中、侍郎郭攸之、费祎、董允等,此皆良实,志虑忠纯,是以先帝简拔以遗陛下。愚以为宫中之事,事无大小,悉以咨之,然后施行,必得裨补阙漏,有所广益。
8.愿陛下托臣以讨贼兴复之效,不效,则治臣之罪,以告先帝之灵。若无兴德之言,则责攸之、祎、允等之慢,以彰其咎;陛下亦宜自谋,以咨诹善道,察纳雅言,深追先帝遗诏,臣不胜受恩感激。
4.将军向宠,性行淑均,晓畅军事,试用之于昔日,先帝称之曰能,是以众议举宠为督。愚以为营中之事,悉以咨之,必能使行阵和睦,优劣得所。
2.宫中府中,俱为一体,陟罚臧否,不宜异同。若有作奸犯科及为忠善者,宜付有司论其刑赏,以昭陛下平明之理,不宜偏私,使内外异法也。
1.先帝创业未半而中道崩殂,今天下三分,益州疲弊,此诚危急存亡之秋也。然侍卫之臣不懈于内,忠志之士忘身于外者,盖追先帝之殊遇,欲报之于陛下也。诚宜开张圣听,以光先帝遗德,恢弘志士之气,不宜妄自菲薄,引喻失义,以塞忠谏之路也。
9.今当远离,临表涕零,不知所言。
6.臣本布衣,躬耕于南阳,苟全性命于乱世,不求闻达于诸侯。先帝不以臣卑鄙,猥自枉屈,三顾臣于草庐之中,咨臣以当世之事,由是感激,遂许先帝以驱驰。后值倾覆,受任于败军之际,奉命于危难之间,尔来二十有一年矣。
7.先帝知臣谨慎,故临崩寄臣以大事也。受命以来,夙夜忧叹,恐付托不效,以伤先帝之明,故五月渡泸,深入不毛。今南方已定,兵甲已足,当奖率三军,北定中原,庶竭驽钝,攘除奸凶,兴复汉室,还于旧都。此臣所以报先帝而忠陛下之职分也。至于斟酌损益,进尽忠言,则攸之、祎、允之任也。
5.亲贤臣,远小人,此先汉所以兴隆也;亲小人,远贤臣,此后汉所以倾颓也。先帝在时,每与臣论此事,未尝不叹息痛恨于桓、灵也。侍中、尚书、长史、参军,此悉贞良死节之臣,愿陛下亲之信之,则汉室之隆,可计日而待也。
public class test {
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new FileReader("FileAndIoStream\\test\\csb"));
        TreeSet<String> set = new TreeSet<>(new Comparator<String>() {
            @Override
            public int compare(String o1, String o2) {
                String num1 = o1.split("\\.")[0];
                String num2 = o2.split("\\.")[0];
                return Integer.parseInt(num1) - Integer.parseInt(num2);
            }
        });

        String line = null;
        while ((line = br.readLine()) != null) {
            set.add(line);
        }
        br.close();

        BufferedWriter bw = new BufferedWriter(new FileWriter("FileAndIoStream\\test\\csb"));
        for (String s : set) {
            bw.write(s);
            bw.newLine();
            bw.flush();
        }
        bw.close();
    }
    public static void mapToSort() throws IOException {
        BufferedReader br = new BufferedReader(new FileReader("FileAndIoStream\\test\\csb"));
        TreeMap<Integer, String> map = new TreeMap<>();
        String line = null;
        while ((line = br.readLine()) != null) {
            String[] split = line.split("\\.");
            map.put(Integer.parseInt(split[0]), line);
        }
        br.close();

        BufferedWriter bw = new BufferedWriter(new FileWriter("FileAndIoStream\\test\\csb"));
        for (Integer integer : map.keySet()) {
            bw.write(map.get(integer));
            bw.newLine();
            bw.flush();
        }
        bw.close();
    }
}

转换流

由于 FileReader 和 FileWriter 无法指定编码 仅可使用平台默认编码 因此若读取/写入其他编码文件会乱码

// java.io.InputStreamReader
// 构造方法
public InputStreamReader(InputStream in, String charsetName)
    String charsetName 指定字符集, 不区分大小写
// java.io.OutputStreamWriter
// 构造方法
public InputStreamReader(OutputStream in, String charsetName)
    String charsetName 指定字符集, 不区分大小写
Reader r = new InputStreamReader(new FileInputStream("FileAndIoStream\\test\\csbGBK.txt"), "gbk");
char[] chs = new char[1024];
int len = 0;
while ((len = r.read(chs)) != -1) {
    System.out.println(new String(chs, 0, len));
}
r.close();

Writer w = new OutputStreamWriter(new FileOutputStream("FileAndIoStream\\test\\csbGBK.txt",true), "gbk");
w.write("\n11.END");
w.close();

练习

复制文件并转换编码

Reader reader = new InputStreamReader(new FileInputStream("FileAndIoStream\\test\\csbGBK.txt"),"gbk");
Writer writer = new OutputStreamWriter(new FileOutputStream("FileAndIoStream\\test\\csbUTF8.txt"));
char[] chars = new char[1024];
len = 0;
while ((len = reader.read(chars)) != -1) {
    writer.write(new String(chars, 0, len));
    writer.flush();
}
reader.close();
writer.close();

序列化

Java 提供了一种对象序列化的机制。用一个字节序列可以表示一个对象,该字节序列包含该对象的数据对象的类型对象中存储的属性等信息。字节序列写出到文件之后,相当于文件中持久保存了一个对象的信息。

反之,该字节序列还可以从文件中读取回来,重构对象,对它进行反序列化对象的数据对象的类型对象中存储的数据信息,都可以用来在内存中创建对象。

  • java.io.ObjectOutputStream 类,将Java对象的原始数据类型写出到文件,实现对象的持久存储。
  • java.io.ObjectInputStream 反序列化流,将之前使用ObjectOutputStream序列化的原始数据恢复为对象
// 构造方法
public ObjectOutputStream(OutputStream out)
// 创建一个指定OutputStream的ObjectOutputStream
public ObjectInputStream(InputStream in)
// 创建一个指定InputStream的ObjectInputStream
public class Demo {
    public static void main(String[] args) throws IOException, ClassNotFoundException {
        writeObject();
        readerObject();

    }

    // 序列化
    public static void writeObject() throws IOException {
        ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("FileAndIoStream\\test\\Person.txt"));
        // 序列化单个对象
        // oos.writeObject(new Person("张三", 17, 1));

        // 序列化多个对象
        List<Person> list = new ArrayList<Person>();
        list.add(new Person("张三",11,1));
        list.add(new Person("李四",15,0));
        list.add(new Person("王五",17,1));
        list.add(new Person("刘六",10,0));

        oos.writeObject(list);
        oos.close();
    }

    // 反序列化
    public static void readerObject() throws IOException, ClassNotFoundException {
        ObjectInputStream ois = new ObjectInputStream(new FileInputStream("FileAndIoStream\\test\\Person.txt"));
        // 反序列化单个对象
        // Person p = (Person) ois.readObject();
        // System.out.println(p);

        // 反序列化多个对象
        Object obj = ois.readObject();
        List<Person> list = (List<Person>) obj;
        for (Person person : list) {
            System.out.println(person);
        }

        ois.close();
    }
}
class Person implements Serializable {
    // 静态内容不能序列化
    private static String className;
    private String name;
    private int age;
    // transient 关键字 瞬态, 不可被序列化
    private transient int sex;
    private static final long serialVersionUID = 1L;

    // 反序列化 不调用构造方法
    public Person() {}
    public Person(String name, int age) {
        this.name = name;
        this.age = age;
    }

    public Person(String name, int age, int sex) {
        this.name = name;
        this.age = age;
        this.sex = sex;
    }

    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }

    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }

    @Override
    public String toString() {
        return "Person{" +
                "name='" + name + '\'' +
                ", age=" + age +
                ", sex=" + sex +
                '}';
    }
}

反序列化时, 若找不到class文件, 则反序列话失败, 抛出异常 ClassNotFoundException
当jvm反序列化对象时, 能找到class文件, 但在序列化对象后class文件发生了改变, 则反序列化失败, 抛出异常 InvalidClassException
当类作为Serializable 的实现类初始化时, 会同时生成一个序列号, 反序列化时检测到序列号不一致

打印流

平时我们在控制台打印输出,是调用print方法和println方法完成的,这两个方法都来自于java.io.PrintStream类,该类能够方便地打印各种数据类型的值,是一种便捷的输出方式

PrintStream类

public PrintStream(String fileName) : 使用指定的文件名创建一个新的打印流。文章来源地址https://www.toymoban.com/news/detail-418613.html

public class Demo {
    public static void main(String[] args) throws IOException {
        PrintWriter p = new PrintWriter("FileAndIoStream\\test\\print1.txt");
        p.print("abc");
        p. println(10);
        p.println(true);
        p.close();
        PrintWriter pw = new PrintWriter(new FileWriter("FileAndIoStream\\test\\print2.txt"),true);
        pw.println("你好");
        // 设置输出位置, 将 输出到控制台 改为 输出到文件
        System.setOut(new PrintStream(new FileOutputStream("FileAndIoStream\\test\\print2.txt", true)));
        System.out.println("输出到文件1");
        System.out.println("输出到文件2");
        pw.close();
    }
}

到了这里,关于java -- 缓冲流、转换流、序列化流的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Web开发模式、API接口、restful规范、序列化和反序列化、drf安装和快速使用、路由转换器(复习)

    一 Web开发模式 1. 前后端混合开发模式 2.前后端分离开发模式 二 API接口 三 restful规范 四 序列化和反序列化 五 drf安装和快速使用

    2024年02月10日
    浏览(44)
  • Java序列化和反序列化

    目录 一、序列化和反序列化 二、Java序列化演示 三、反序列化漏洞 1、含义 ​序列化就是内存中的对象写入到IO流中,保存的格式可以是二进制或者文本内容。反序列化就是IO流还原成对象。 2、用途 (1)传输网络对象 (2)保存Session 1、序列化 java.io.ObjectOutputStream代表对象

    2023年04月25日
    浏览(39)
  • 【Java 基础篇】Java序列化与反序列化详解

    在Java中,序列化和反序列化是一种将对象转换为字节流和将字节流转换为对象的机制。通过序列化,可以将对象存储到文件中、传输到网络上,或者在分布式系统中进行对象的传递。本文将详细介绍Java序列化和反序列化的原理、使用方法和常见应用场景,并提供一些示例代

    2024年02月09日
    浏览(37)
  • Java安全基础之Java序列化与反序列化

    目录 ObjectInputStream 和 ObjectOutputStream java.io.Serializable 自定义序列化和反序列化 Java 的序列化(Serialization)是指将对象转换为字节序列的过程,而反序列化(Deserialization)则是将字节序列转换回对象的过程。 序列化和反序列化通常用于在网络上传输对象或者将对象持久化到文

    2024年04月22日
    浏览(39)
  • Java序列化和反序列化机制

    在阅读 ArrayList 源码的时候,注意到,其内部的成员变量动态数组 elementData 被Java中的 transient 修饰 transient 意味着Java在序列化时会跳过该字段(不序列化该字段) 而Java在默认情况下会序列化类(实现了 Java.io.Serializable 接口的类)的所有非瞬态(未被 transient 修饰

    2024年03月15日
    浏览(50)
  • [Java反序列化]—Shiro反序列化(一)

    IDEA搭建shiro550复现环境_普通网友的博客-CSDN博客 Apache Shiro框架提供了记住密码的功能(RememberMe),用户登录成功后会生成经过加密并编码的cookie。在服务端对rememberMe的cookie值,先base64解码然后AES解密再反序列化,就导致了反序列化RCE漏洞。 那么,Payload产生的过程: 命令

    2024年02月06日
    浏览(43)
  • Java 反序列化之 XStream 反序列化

    XStream 是一个简单的基于 Java 库,Java 对象序列化到 XML,反之亦然(即:可以轻易的将 Java 对象和 XML 文档相互转换)。 下面看下如何使用 XStream 进行序列化和反序列化操作的。 先定义接口类 IPerson.java 接着定义 Person 类实现前面的接口: XStream 序列化是调用  XStream.toXML()  来实

    2024年02月10日
    浏览(58)
  • java中的序列化和反序列化

    objectOutputStream 对象的序列化,以流的形式将对象写入文件 构造方法: objectOutputStream(OutputStream out) 传入一个字节输入流创建objectOutputStream对象 成员方法: void writeObject(object obj) 将指定的对象写入objectOutputStream 使用步骤: 创建一个类,这个类实现Serializable接口,Serializable是一

    2024年02月14日
    浏览(35)
  • Java中序列化和反序列化解释

    在Java中,序列化(Serialization)是指将对象的状态转换为字节流的过程,以便将其保存到文件、在网络中传输或持久化到数据库中。而反序列化(Deserialization)则是将字节流转换回对象的过程,恢复对象的状态。 序列化和反序列化主要用于以下场景: 1. 对象持久化:通过序列

    2024年02月07日
    浏览(56)
  • Java反序列化:URLDNS的反序列化调试分析

    URLDNS链子是Java反序列化分析的第0课,网上也有很多优质的分析文章。 笔者作为Java安全初学者,也从0到1调试了一遍,现在给出调试笔记。 Java原生链序列化:利用Java.io.ObjectInputStream对象输出流的writerObject方法实现Serializable接口,将对象转化成字节序列。 Java原生链反序列化

    2024年02月15日
    浏览(37)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包