对于这道题,绝大多数的答案都是“可以存储”。给出的原因包括:

  1. java中的char是unicode存储,unicode编码字符集中包含了汉字,所以可以存储中文;

  2. java内部其实是使用的UTF-16的编码,所以是支持大部分非生僻汉字的;

  3. 采用Unicode编码集,一个char占用两个字节,而一个中文字符也是两个字节,因此Java中的char是可以表示一个中文字符的;

  4. Java的char只能表示utf­16中的BMP部分中文字符,不能表示扩展字符集里的中文字符;

原文地址:https://docs.oracle.com/javase/7/docs/api/java/lang/Character.html

char类型是按照Unicode规范实现的一种数据类型,固定16bit大小。现如今,Unicode字符集已经进行了扩展,表示的范围已经超过了16bit。Unicode字符集的数值范围扩大到了[U+0000,U+10FFFF]。

也就是说一个char能够存储16bit大小的数值,即2个字节。但是,就常用的UTF-8编码来说,我们都听说过他是用3或者4个字节来表示一个汉字的。就拿3个字节来算的话,一个char也存不下是不是?

我们继续看api文档的其他段落:

而且,绝大部分的中文字符的Unicode范围是[0x4E00, 0x9FBB],恰好是在BMP范围内。

是不是说这里出现了破解不了的矛盾呢?UTF-8占用3到4个字节,char只能存2个字节(16bit),然而UTF-8中的几乎所有汉字都是在BMP范围内,也就是在char可存储的范围内,是不是矛盾了?

一个char值可以表示BMP范围内的Unicode字符。BMP表示[U+0000, U+FFFF]之间的Unicode字符。

答案是不矛盾!关键点就在于接下来给出总结的第一条!

这里先给出总结,后续再给出解释:

1.char字符存储的是Unicode编码的代码点,也就是存储的是U+FF00这样的数值,然而我们在调试或者输出到输出流的时候,是JVM或者开发工具按照代码点对应的编码字符输出的。

  1. 所以虽然UTF-8编码的中文字符是占用3个或者4个字节,但是对应的代码点仍然集中在[0x4E00, 0x9FBB],所以char是能够存下在这个范围内的中文字符的。

  2. 但是对于超过16bit的Unicode字符集,也就是Unicode的扩展字符集,一个char是放不下的,需要两个char才能放下。

Unicode编码
Unicode的出现是对混乱的ANSI编码世界的一个大一统,因而也叫做统一码、万国码、单一码。Unicode编码把世界上常用的语言字符都进行了统一的编码,一个数值就代表一个字符,而且世界范围内公认。

ANSI的编码世界里,各中语言有自己的编码规范,同一个数值在不同的国家代表不同的字符。所以当文字在不同国家传递的时候(比如发邮件,看国外网页),问题就很大了,我明明写的是“爱我中华”,美国朋友看到的确实”°®ÎÒÖлª”,一定是一脸问号!

//=模拟文字在不同编码语言间传递的过程=

//发帖子

String s = “爱我中华”;

//编码成字节流,通过网络传入,或者存储到文件

byte[] bytes = s.getBytes(“GB2312”);

System.out.println(s);

//国外朋友用自己电脑的编码方式解析字节流

String s2 = newString(bytes, “ISO-8859-1”);

//oh! shit, wtf!

System.out.println(s2);

有了Unicode这个统一编码之后,全世界的计算机都能正确的解析到原始的字符,对于国内的文字信息,国外的朋友唯一要做的就是懂中文!

UTF-8只是Unicode编码的一种编码转换规范,也就是怎么存储Unicode代码点的方案之一。另外还有UTF-16和UTF-32等编码规范。Unicode为什么需要这么多编码规范?直接存储代码点行不行?

当然不行,存储了就需要解析比如”汉字”两个字的Unicode代码点是“0x6c49和0x5b57”也就是”6c495b57”。而且,Unicode的代码点还有3个字节的,比如”10FF3B”,对于一个很长的上述数字串该怎么解析?比如“10FF3B6c495b57”!

所以,需要某种编码方案来区分那几个数值是一个Unicode代码点,这种方案就是UTF-8、UTF-16、UTF-32这样的编码方案。

UTF-8编码和代码点对应关系
UTF-8以字节为单位对Unicode进行编码。从Unicode到UTF-8的编码方式如下:

Unicode编码(十六进制)    UTF-8 字节流(二进制)

000000-00007F                0xxxxxxx

000080-0007FF                110xxxxx 10xxxxxx

000800-00FFFF                1110xxxx 10xxxxxx 10xxxxxx

010000-10FFFF                11110xxx10xxxxxx10xxxxxx10xxxxxx

有没有发现点什么?当一个字节表示一个字符时,二进制开头是0;当两个字节表示一个字符时,二进制开头是11;当3个字节表示一个字符时,二进制开头是111;依次类推!

UTF-8编码加入了多余的标识位来区分一个Unicode代码点!才会出现中文汉字集中在[0x4E00, 0x9FBB]范围的16bit数值内,UTF-8却需要3个字节存储的原因。

作者:温走马
链接:https://www.jianshu.com/p/4c29d96d5e06
来源:简书
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

Java里的char类型能不能存储一个中文字符?相关推荐

  1. Java的char数据类型存储一个中文字符

    对于Java语法以及JVM框架,实际上是用之,而不是先掌握,所以对一些基础性概念总是存在偏颇认识. 比如对于这个char类型来说,一直以为是一个字节的变量,那自然不能存储一个中文字符(2个字节),这是 ...

  2. 【Java基础】Java中的char是否可以存储一个中文字符之理解字符字节以及编码集

    Java中的一个char采用的是Unicode编码集,占用两个字节,而一个中文字符也是两个字节,因此Java中的char是可以表示一个中文字符的. 但是在C/C++中由于采用的字符编码集是ASCII, ...

  3. Java的编码方式、单个char类型存储大部分中文字符、getBytes()、new String()的转换流程

    目录 一 编码种类 1.1 ASCII码 1.2 ISO8859-1编码 1.3 GBK编码 1.4 Unicode字符集 1.4.1 UTF-8编码 1.4.2 UTF-16编码 1.4.3 UTF ...

  4. JAVA里面的int类型 和Integer类型,有什么不一样

    JAVA里面的int类型 和Integer类型,有什么不一样 原创 2013年09月04日 23:15:11 标签: java / 2120 编辑 删除 JAVA里面的int类型 和Integer类型 ...

  5. java如何将char类型的数字转换成int型的数字

    java如何将char类型的数字转换成int型的数字 public class CharToIntConverter {public static void main(String[] args) { ...

  6. char型变量能不能存储一个中文汉字重写和重载的规则

    char型变量能不能存储一个中文汉字(为什么) char类型可以存储一个中文汉字 因为java中使用的编码是Unicode格式,而一个char类型占2个字节(16比特),所以当一个中文汉字是没有问题的 ...

  7. char变量能不能存储一个汉字

    在C语言中,char类型占1一个字节,而汉子占2个字节,所以不能存储.在Java中,char类型占2个字节,而且Java默认采用Unicode编码,以个Unicode码是16位,所以一个Unicode ...

  8. java a标签正则_正则表达式:java中婚配HTML中a标签中的中文字符

    正则表达式:java中匹配HTML中a标签中的中文字符 今天群里一位朋友问到了一个正则表达式的问题,有如下内容: 特432 453543 a1特123你好123吗? 特2 标签中的文字现在要匹配出内容 ...

  9. 面试题:问题:Java中,char型变量中能不能存储一个中文汉字,为什么?

    * char型变量是用来存储Unicode编码的字符的,unicode编码字符集中包含了汉字,  * 所以,char型变量中当然可以存储汉字啦.不过,如果某个特殊的汉字没有被包含在  * unicod ...

最新文章

  1. mysql用户ip登录失败怎么办_MySQL使用IP地址登录 ERROR 1045 (28000) Access denied for use...
  2. RDKit | 比较分子之间的相似性
  3. 定点量化误差python仿真.零极点(1)
  4. 批评代码而不是人!15年程序员的职场箴言
  5. Python原来这么厉害,我震惊了!
  6. 微服务组件记事本:Skywalking执行效果 · 多图篇
  7. 嘲弄和存根–了解Mockito的测试双打
  8. 2021年中国电缆吹风机市场趋势报告、技术动态创新及2027年市场预测
  9. docker es持久化_docker如何保持数据持久化?其实可以考虑通过数据卷挂载的方式~...
  10. 编程笔记:python 中的 OrderedDict
  11. [BZOJ 1070] [SCOI2007] 修车
  12. 【视频】文本挖掘:主题模型(LDA)及R语言实现分析游记数据
  13. 2013武汉住房公积金新政详解
  14. Kubernetes
  15. idea 提示cannot find declaration to go to 解决方法
  16. 搭建直播平台过程中的全能“辅助”——流媒体服务器
  17. PHPWord利用模板替换字符串生成精确的word文档
  18. 如何先梳理业务逻辑再写代码
  19. 计算机网络与数据库应用技术
  20. 霍比特E姐有约|Exploit Network 如何打造 Web3.0 匿名支付协议

热门文章

  1. 蓝牙耳机音质变差或许该注意这些问题,学生党什么牌子蓝牙耳机性价比高?
  2. html Antv L7 + mapbox 实现3D地图 3D中国地图 不限于中国地图
  3. 反向代理和正向代理详解
  4. SQL Server 数据库修复专家SQLRescue
  5. SQL Server 数据库修复步骤
  6. 世界海洋日 | TcaplusDB号召你一同保护海洋生物多样性
  7. 计算机里面怎么建新的文档,【2人回答】怎样在电脑新建中添加Word文档?-3D溜溜网...
  8. java开发速成班培训课程(1)
  9. 文心一格x网易「EVE宇宙航母预研」主题AI绘画大赛即将开启!
  10. 【大白话学习】UniApp 微信小程序与APP应用 开发零基础入门教程(二)---登陆界面功能实现