Java中的IO流字节流(FileOutputStream与FileInputStream)+编码与解码

2024-06-09 02:36

本文主要是介绍Java中的IO流字节流(FileOutputStream与FileInputStream)+编码与解码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

​编辑

IO流

File0utputstream 

FileOutputstream写数据的3种方式

void write(int b)     一次写一个字节数据

void write(byte[] b)     一次写一个字节数组数据

void write(byte[] b,int off,int len)   一次写一个字节数组的部分数据 

FileOutputstream写数据的两个小问题

该如何换行呢?

FilelnputStream

文件拷贝

编码与解码

编码 

解码 


 IO流

Java中的IO流是用于输入和输出数据的工具。Java的IO流分为字节流和字符流两种类型。

字节流可以操作所有类型的文件   

字符流可以操作纯文本文件(纯文本文件就是windows自带的笔记本打开能读懂的)

字节流:

  • InputStream和OutputStream:用于读取和写入二进制数据(字节)。
  • FileInputStream和FileOutputStream:用于读取和写入文件的字节流。
  • ByteArrayInputStream和ByteArrayOutputStream:用于读写字节数组的字节流。
  • BufferedInputStream和BufferedOutputStream:用于提供带缓冲的字节流,提高IO性能。

字符流:

  • Reader和Writer:用于读取和写入字符数据。
  • FileReader和FileWriter:用于读取和写入文件的字符流。
  • CharArrayReader和CharArrayWriter:用于读写字符数组的字符流。
  • BufferedReader和BufferedWriter:用于提供带缓冲的字符流。

File0utputstream 

字节输出流,可以把程序中的数据写到本地文件上,是字节流的基本流 

写出一段文字到本地文件中。👇

package io;import java.io.FileOutputStream;
import java.io.IOException;public class ioDemo1 {public static void main(String[] args) throws IOException {FileOutputStream fos=new FileOutputStream("..\\Myio\\a.txt");fos.write(97);fos.close();}
}

如果文件不存在会创建一个新的文件,但是要保证父级路径是存在的。 

 

如果文件已经存在,则会清空文件👇 

运行之后👇 

字节输出流:

1.创建字节输出流对象

  • 参数是字符串表示的路径或者是File对象都是可以的
  • 如果文件不存在会创建一个新的文件,但是要保证父级路径是存在的。
  • 如果文件已经存在,则会清空文件

2.写数据

write方法的参数是整数,但是实际上写到本地文件中的是整数在ASCII上对应的字符

每次使用完流之后都要释放资源

FileOutputstream写数据的3种方式

void write(int b)     一次写一个字节数据
void write(byte[] b)     一次写一个字节数组数据
void write(byte[] b,int off,int len)   一次写一个字节数组的部分数据 

void write(int b)     一次写一个字节数据

void write(byte[] b)     一次写一个字节数组数据

package io;import java.io.FileOutputStream;
import java.io.IOException;public class ioDemo1 {public static void main(String[] args) throws IOException {FileOutputStream fos=new FileOutputStream("..\\Myio\\a.txt");byte[] bytes={97,98,99};fos.write(bytes);fos.close();}
}

 

void write(byte[] b,int off,int len)   一次写一个字节数组的部分数据 

 参数一:数组,参数二:起始索引,参数三:个数

package io;import java.io.FileOutputStream;
import java.io.IOException;public class ioDemo1 {public static void main(String[] args) throws IOException {FileOutputStream fos=new FileOutputStream("..\\Myio\\a.txt");byte[] bytes={97,98,99};fos.write(bytes,1,2);fos.close();}
}

FileOutputstream写数据的两个小问题

该如何换行呢?

package io;import java.io.FileOutputStream;
import java.io.IOException;public class ioDemo2 {public static void main(String[] args) throws IOException {FileOutputStream fos = new FileOutputStream("..\\Myio\\a.txt");//写出数据String str = "niihao";byte[] bytes1 = str.getBytes();fos.write(bytes1);String str2="\n";byte[] bytes2 = str2.getBytes();fos.write(bytes2);String str3="csdn";byte[] bytes3 = str3.getBytes();fos.write(bytes3);//释放资源fos.close();}
}

这里的\n为换行 

 

那又该如何续写?再次运行不会清空上次的数据呢?

package io;import java.io.FileOutputStream;
import java.io.IOException;public class ioDemo2 {public static void main(String[] args) throws IOException {FileOutputStream fos = new FileOutputStream("..\\Myio\\a.txt",true);//写出数据String str = "niihao";byte[] bytes1 = str.getBytes();fos.write(bytes1);String str2="\n";byte[] bytes2 = str2.getBytes();fos.write(bytes2);String str3="csdn";byte[] bytes3 = str3.getBytes();fos.write(bytes3);//释放资源fos.close();}
}

 

如果想要续写。打开续写开关即可开关位置:创建对象的第二个参数

默认false:表示关闭续写,此时创建对象会消空文件手动传递true:表示打开续写,此时创建对象不

会清空文件

FilelnputStream

操作本地文件的字节输入流,可以把本地文件中的数据读取到程序中来 

1、创建字节输入流对象

如果文件不存在,就直按报错。

2.写数据

一次读一个字节,读出来的是数据在ASCII上对应的数字

读到文件末尾了,read方法返回-1。

3.释放资源
细节:每次使用完流之后都要释放资源

 

package inputio;import java.io.FileInputStream;
import java.io.IOException;public class inputDemo1 {public static void main(String[] args) throws IOException {//创建字节输入流对象FileInputStream fis=new FileInputStream("..\\Myio\\b.txt");//读取数据int r1 = fis.read();System.out.println(r1);int r2 = fis.read();System.out.println(r2);int r3 = fis.read();System.out.println(r3);int r4 = fis.read();System.out.println(r4);//释放资源fis.close();}
}

 

可以看到最后一次读到文件末尾了,read方法返回-1。

字节输入流的循环读取👇

package inputio;import java.io.FileInputStream;
import java.io.IOException;public class inputDemo2 {public static void main(String[] args) throws IOException {//创建字节输入流对象FileInputStream fis=new FileInputStream("..\\Myio\\b.txt");int b=0;//循环读取while((b=fis.read())!=-1){System.out.println((char)b);}//释放资源fis.close();}}

一次读取多个字节数据,具体读多少,跟数组的长度有关

返回值:本次读取到了多少个字节数据

package inputio;import java.io.FileInputStream;
import java.io.IOException;public class inputDemo3 {public static void main(String[] args) throws IOException {FileInputStream fis=new FileInputStream("..\\Myio\\a.txt");byte[] bytes=new byte[2];int len1 = fis.read(bytes);String str1=new String(bytes);System.out.println(str1);System.out.println(len1);System.out.println("----------------------");int len2 = fis.read(bytes);String str2=new String(bytes);System.out.println(str2);System.out.println(len2);System.out.println("----------------------");int len3 = fis.read(bytes);String str3=new String(bytes);System.out.println(str3);System.out.println(len3);System.out.println("----------------------");int len4 = fis.read(bytes);String str4=new String(bytes);System.out.println(str4);System.out.println(len4);fis.close();}
}

 

第3次读取到的数据为什么是ed呢?

这是第一次读取到的👇len为2

这是第二次读取到的👇len为2

a跟b都被覆盖了

这是第三次读取👇len为1

可以发现c被覆盖了,d没有被覆盖,这是因为只读取到了一个数据

还可以给这个代码优化一下

package inputio;import java.io.FileInputStream;
import java.io.IOException;public class inputDemo3 {public static void main(String[] args) throws IOException {FileInputStream fis=new FileInputStream("..\\Myio\\a.txt");byte[] bytes=new byte[2];int len1 = fis.read(bytes);String str1=new String(bytes,0,len1);System.out.println(str1);System.out.println(len1);System.out.println("----------------------");int len2 = fis.read(bytes);String str2=new String(bytes,0,len2);System.out.println(str2);System.out.println(len2);System.out.println("----------------------");int len3 = fis.read(bytes);String str3=new String(bytes,0,len3);System.out.println(str3);System.out.println(len3);fis.close();}
}

 

文件拷贝

将abc拷贝进a.txt中

package inputio;import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;public class IODemo {public static void main(String[] args) throws IOException {FileInputStream fis=new FileInputStream("D:\\b.txt");FileOutputStream fos=new FileOutputStream("..\\Myio\\a.txt");int b=0;while((b=fis.read())!=-1){fos.write(b);}fos.close();fis.close();}
}

 

但是这样写对于文件过大的情况,运行的会非常的慢

下面我们来优化一下

package inputio;import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;public class IODemo2 {public static void main(String[] args) throws IOException {FileInputStream fis=new FileInputStream("D:\\b.txt");FileOutputStream fos=new FileOutputStream("..\\Myio\\a.txt");//这里的大小设置为1024的整数倍就好了byte[] bytes=new byte[1024];int len=0;while ((len=fis.read(bytes))!=-1){fos.write(bytes,0,len);}fos.close();fis.close();}
}

编码与解码

我们先了解一下这个👇

GBK字符集完全兼容ASCII字符集

一个英文占一个字节,二进制第一位是0

一个中文占两个字节,二进制高位字节的第一位是1

以下为GBK字符集中编码之后的二进制,请说出有几个中文,几个英文

Unicode字符集的UTF-8编码格式

一个英文占一个字节,二进制第一位是0,转成十进制是正数

一个中文占三个字节,二进制第一位是1,第一个字节转成十进制是负数

Java中编码的方法

  • public byte[] getBytes()                使用默认方式进行编码
  • public byte[]getBytes(string charsetName)                        使用指定方式进行编码

Java中解码的方法

  • string(byte[] bytes)        使用默认方式进行解码
  • string(byte[] bytes,string charsetName)                使用指定方式进行解码 

编码 

import java.io.UnsupportedEncodingException;
import java.util.Arrays;public class ioDemo1 {public static void main(String[] args) throws UnsupportedEncodingException {String str="ai你呀";byte[] bytes1 = str.getBytes();System.out.println(Arrays.toString(bytes1));byte[] bytes2 = str.getBytes("GBK");System.out.println(Arrays.toString(bytes2));}
}

Java默认的是UTF-8

解码 

import java.io.UnsupportedEncodingException;
import java.util.Arrays;public class ioDemo1 {public static void main(String[] args) throws UnsupportedEncodingException {//编码String str="ai你呀";byte[] bytes1 = str.getBytes();System.out.println(Arrays.toString(bytes1));//解码String s1 = new String(bytes1);System.out.println(s1);String s2 = new String(bytes1, "GBK");System.out.println(s2);}
}

 

UTF-8一个英文占一个字节,一个中文占三个字节

 

GBK字符集一个英文占一个字节一个中文占两个字节

 


IO流的字节流就先说到这啦!!!感谢各位观看

字节流在这👇

 想先占个位😀

 

这篇关于Java中的IO流字节流(FileOutputStream与FileInputStream)+编码与解码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

字节面试 | 如何测试RocketMQ、RocketMQ?

字节面试:RocketMQ是怎么测试的呢? 答: 首先保证消息的消费正确、设计逆向用例,在验证消息内容为空等情况时的消费正确性; 推送大批量MQ,通过Admin控制台查看MQ消费的情况,是否出现消费假死、TPS是否正常等等问题。(上述都是临场发挥,但是RocketMQ真正的测试点,还真的需要探讨) 01 先了解RocketMQ 作为测试也是要简单了解RocketMQ。简单来说,就是一个分

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟 开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚 第一站:海量资源,应有尽有 走进“智听