关于java 中 各种字符集的问题

我的一些概念,不是很肯定是否正确,请高人指点。

相关的因素有:源码的字符集,编译时的字符集,运行时的字符集。

1,String 中储存的是 char[] ,每个char中存放的unicode 字符,每个unicode 包含两个字节(不管中文,英文,还是哪种语言),char对应数值 就是字符在UNICODE中对应的号码。

2,源码编译成class文件后,String字符串在class中为UTF8码。所以如果源码中的字符串包含中文的话,只有用相应的环境的字符集来编译(javac -encoding)才能得到正确的UTF8码。源码的字符集和编译时所用字符集需要一致。

3,程序运行时,String.getBytes()等函数所用的默认字符集为当前运行环境的字符集,不是编译时所用字符集。

 4,String.getBytes(charset) 其过程是,字符串中每个字符char(其实存储的是字符UNICODE中的号码)映射到字符集charset 中的相同字符,得到这个字符在字符集charset中的号码(String.getBytes(charset)得到的 byte[]也就是这个号码的表示)。当字符集charset不包含字符 char是,这种映射就不成功。比如char中是中文字,String.getBytes("ISO-8859-1")的时候,由于ISO-8859-1不包含中文字,这个时候得到的byte[] 就是一个63,也就是ISO-8859-1的字符'?'(字符集将不认识的字符默认映射到'?').

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值