【JAVA IO】_字符编码笔记

【JAVA IO】_字符编码笔记

本章目标:
了解常用的几种编码
掌握乱码的产生原因

3、具体内容

编码:在计算机世界里,任何的文字都是以指定的编码方式存在的,在java程序开发中最常见的是以下几种编码:ISO8859-1 、GBK/GB2312、unicode、UTF

iso8859-1编码属于单字节编码,最多只能表示0~255的字符范围,主要在英文上应用。
GBK/GB2312:中文的国际编码,专门用来表示汉字,是双字节编码。
unicode:java中就是使用此编码方式,也是最标准的一种编码,是使用16进制表示的编码。但此编码不兼容iso8859-1编码。
UTF:由于unicode不支持iso8859-1编码,而且容易占用更多的空间,而且对于英文字母也需要使用两个字节编码,这样使用unicode不便于传输和存储,因此产生了utf编码,utf编码兼容了iso8859-1编码,同时也可以用来表示所有的语言字符,不过utf编码是不定长编码,第一个字符长度1-6个字节不等,一般中文网页中使用此编码,因为这样可以节省空间。

得到本机的编码显示

public class CharSetDemo01{
    public static void main(String args[]){
        System.out.println("系统默认编码:"+System.getProperty("file.encoding"));    //获取当前系统编码    
    }
}



可以使用String类转换字符的编码。

import java.io.OutputStream ;
import java.io.FileOutputStream ;
import java.io.File ;
public class CharSetDemo02{
    public static void main(String args[]) throws Exception {
        File f = new File("D:" + File.separator + "test.txt") ;    // 实例化File类
        OutputStream out = new FileOutputStream(f) ;    // 实例化输出流
        byte b[] = "中国,你好!".getBytes("ISO8859-1") ;    // 转码操作
        out.write(b) ;    // 保存
        out.close() ;    // 关闭
    }
};


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

e421083458

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

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

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

打赏作者

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

抵扣说明:

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

余额充值