转换流
字符编码
计算机中存储的信息都是用二进制数表示的,而我们在屏幕上看到的数字、英文、标点符号,汉字等字符是二进制数转换之后的结果,按照某种规则,将字符存储到计算机中,称为编码,反之,将存储在计算机中的二进制数按照某种规则解析显示出来,称为解码。比如说,按照A规则存储,同样按照A规则解析,那么就能显示正确的文本符号。反之,按照A规则存储,再按照B规则解析,就会导致乱码现象。
编码:字符(能看懂)--> 字节(看不懂)
解码:字节(看不懂)--> 字符(能看懂)
字符集:也叫编码表,是一个系统支持的所有字符的集合,包括各国家文字、标点符号、图形符号、数字等。
计算机要准确的存储和识别各种字符集符号,需要进行字符编码,一套字符集必然至少有一套字符编码。长剑字符集有ASCII字符集、GBK字符集、Unicode字符集等。
常见的字符集有:ASCII字符集、GBK字符集、Unicode字符集。
编码引出的问题
在IDEA中,使用FileReader,读取项目中的文本文件,由于IDEA的设置,都是默认的UTF-8编码,所有没有任何问题。但是,当读取Windows系统中创建的文本文件时,由于Windows系统的默认GBK编码,就会出现乱码。
package day10;
import java.io.FileReader;
import java.io.IOException;
public class Demo02 {
public static void main(String[] args) throws IOException {
FileReader fr = new FileReader("C:\\a\\GBK编码.txt");
int len = 0;
while((len = fr.read())!=-1){
System.out.print((char)len);
}
fr.close();
}
}
InputStreamWriter
java.io.OutputStreamWriter extends Writer
OutputStreamWriter:是字符流桐乡字节流的乔辽;可使用指定的charset将要写入流中的字符编码成字节。
继承自父类的共性成员方法:
- void write(int c)写入单个字符。
- void write(char[] cbuf)写入字符数组。
- abstract void write(char[] cbuf,int off,int len)写入字符数组的某一部分,off数组的开始索引,len写的字符个数。
- void write(String str)写入字符
- void write(String str,int off,int len)写入字符串的某一部分,off字符串的开始索引,len写的字符个数。
- void flush()刷新该流的缓冲。
- void close()关闭此流,但要先刷新它。
构造方法:
OutputStreamWriter(OutputStream out) 创建使用默认字符编码的OutputStreamWriter。
OutputStreamWriter(OutputStream out,String charsetName) 创建使用指定字符集的OutputStreamWriter.
参数:
OutputStream out:字节输出流,可以用来写转换之后的字节到文件中
String charsetName:指定的编码表名称,不区分大小写,可以是UTF-8/UTF-8,GBK/GBK,....不指定默认使用UTF-8
使用步骤:
- 创建OutputStreamWriter对象,构造方法中传递字节输出流和指定的编码表名称。
- 使用OutputStreamWriter对象中的方法write,把字符转换为字节存储缓冲区中(编码)
- 使用OutputStreamWriter对象中的方法flush,把内存缓冲区中的字节刷新到文件中(使用字节流写字节的过程)
- 释放资源。
package day10;
import java.io.*;
public class Demo01 {
public static void main(String[] args) throws IOException {
write_gbk();
write_utf_8();
}
private static void write_gbk() throws IOException {
OutputStreamWriter osw = new OutputStreamWriter(new FileOutputStream("C:\\a\\gbk.txt"), "gbk");
osw.write("你好");
osw.flush();
osw.close();
}
private static void write_utf_8() throws IOException {
OutputStreamWriter osw = new OutputStreamWriter(new FileOutputStream("C:\\a\\utf-8.txt"), "utf-8");
osw.write("你好");
osw.flush();
osw.close();
}
}
InputStreamReader
java.io.InputStreamReader extends Reader
InputStreamReader:是字节流通向字符流的桥梁,它使用指定的charset读取字节并将其解码为字符。
继承自父类的共性成员方法:
int read() 读取单个字符并返回。
int read(char[] cbuf) 一次读取多个字符,将字符读入数组。
void close() 关闭该流并释放与之关联的所有资源。
构造方法:
InputStreamReader(InputStream in) 创建一个使用默认字符集的 InputStreamReader。
InputStreamReader(InputStream in,String charsetName) 创建使用指定字符集的InputStreamReader。
参数:
InputStream in:字节输入流,用来读取文件中保存的字节
String charsetName:指定的编码表名称,不区分大小写,可以是utf-8/utf-8,gbk/utf-8,....不指定默认使用utf-8。
使用步骤:
- 创建InputStreamReader对象,构造方法中传递字节输入流和指定的编码表名称。
- 使用InputStreamReader对象中的方法read读取文件。
- 释放资源。
注意事项:
构造方法中指定的编码表名称要和文件的编码相同,否则会发生乱码。
package day10;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStreamReader;
public class Demo03 {
public static void main(String[] args) throws IOException {
read_utf_8();
read_gbk();
}
private static void read_gbk() throws IOException {
InputStreamReader isr = new InputStreamReader(new FileInputStream("C:\\a\\gbk.txt"),"gbk");
int len = 0;
while((len = isr.read())!=-1){
System.out.println((char)len);
}
isr.close();
}
private static void read_utf_8() throws IOException {
InputStreamReader isr = new InputStreamReader(new FileInputStream("C:\\a\\utf-8.txt"),"utf-8");
int len = 0;
while((len = isr.read())!=-1){
System.out.println((char)len);
}
isr.close();
}
}
练习:转换文件编码
需求:将gbk编码的文本文件,转换为utf-8编码的文本文件。
分析:
- 读取一个gbk编码的文件
- 创建一个utf-8编码的文件,存储编码转换之后的文件。
- 使用read方法读取文件内容,将其存储到编码之后的文件中。
package day10;
import java.io.*;
public class lianxi {
public static void main(String[] args) throws IOException {
InputStreamReader isr = new InputStreamReader(new FileInputStream("C:\\a\\GBK编码.txt"),"gbk");
OutputStreamWriter osw = new OutputStreamWriter(new FileOutputStream("C:\\a\\UTF-8编码.txt"),"utf-8");
int len = 0;
while ((len = isr.read())!=-1){
osw.write(len);
}
osw.close();
isr.close();
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· AI与.NET技术实操系列(六):基于图像分类模型对图像进行分类