13-5 IO流 ---- 处理流之二:转换流(1)概述

13-5 IO流 ---- 处理流之二:转换流(1)概述

一、概述
1.转换流提供了在字节流和字符流之间的转换
2.Java API提供了两个转换流:
(1)InputStreamReader:将InputStream转换为Reader
(2)OutputStreamWriter:将Writer转换为OutputStream

3.字节流中的数据都是字符时,转成字符流操作更高效。
4.很多时候我们使用转换流来处理文件乱码问题。实现编码和解码的功能

二、InputStreamReader
1.实现将字节的输入流按指定字符集转换为字符的输入流。
2.需要和InputStream“套接”。
3.构造器
(1)public InputStreamReader(InputStream in)
(2)public InputSreamReader(InputStream in,String charsetName)
如: Reader isr = new InputStreamReader(System.in,”gbk”);
(“gdk”指定字符集)

三、OutputStreamWriter
1.实现将字符的输出流按指定字符集转换为字节的输出流。
2.需要和OutputStream“套接”。
3.构造器
(1)public OutputStreamWriter(OutputStream out)
(2)public OutputSreamWriter(OutputStream out,String charsetName)

在这里插入图片描述
四、补充:字符编码
1.编码表的由来
计算机只能识别二进制数据,早期由来是电信号。为了方便应用计算机,让它可以识别各个国家的文字。就将各个国家的文字用数字来表示,并一一对应,形成一张表。这就是编码表。

2.字符集(常见编码表)
(1)ASCII:美国标准信息交换码。用一个字节的7位可以表示。
(2)ISO8859-1:拉丁码表。欧洲码表用一个字节的8位表示。
(3)GB2312:中国的中文编码表。最多两个字节编码所有字符
(4)GBK:中国的中文编码表升级,融合了更多的中文文字符号。最多两个字节编码
(5)Unicode:国际标准码,融合了目前人类使用的所有字符。为每个字符分配唯一的字符码。所有的文字都用两个字节来表示。
(6)UTF-8:变长的编码方式,可用1-4个字节来表示一个字符。

(在Unicode出现之前,所有的字符集都是和具体编码方案绑定在一起的(即字符集≈编码方式),都是直接将字符和最终字节流绑定死了。GBK等双字节编码方式,用最高位是1或0表示两个字节和一个字节。)

3.Unicode不完美,这里就有三个问题,一个是,我们已经知道,英文字母只用一个字节表示就够了,第二个问题是如何才能区别Unicode和ASCII?计算机怎么知道两个字节表示一个符号,而不是分别表示两个符号呢?第三个,如果和GBK等双字节编码方式一样,用最高位是1或0表示两个字节和一个字节,就少了很多值无法用于表示字符,不够表示所有字符。Unicode在很长一段时间内无法推广,直到互联网的出现。

4.面向传输的众多 UTF(UCS Transfer Format)标准出现了,顾名思义,**UTF- 8就是每次8个位传输数据,而UTF-16就是每次16个位。**这是为传输而设计的编码,并使编码无国界,这样就可以显示全世界上所有文化的字符了。

5.**Unicode只是定义了一个庞大的、全球通用的字符集,并为每个字符规定了唯一确定的编号,具体存储成什么样的字节流,取决于字符编码方案。**推荐的Unicode编码是UTF-8和UTF-16。
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

YY鸟

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值