“在JAVA中的字符是Unicode编码,是双字节的。InputStream类,是用来处理字节的,并不适合处理字符文本”这句话该怎么理解?这双字节编码、字节处理、字符文本又该怎么理解?我是新手求调教下。
3条回答 默认 最新
- tang_cheng 2016-12-29 03:52关注
你的一个字符串就是一个String,每个String里的每个字都是一个char(字符),你可以通过String.charAt()函数获取字符串中的char。这个char包含了所有的英文,中文,符号和其他各国语言。所以它的内部是用一个16位的整数来保存的,这就是文档上说的UNICODE编码。
我们如果只在程序内部操作字符串,那最多只要关心到char就足够了。但是如果保存到文件中,就要把char转换成byte(字节)。因为在文件中是以字节为单位存储的。
而且由于现在char转byte的转换方式已经成型了很多编码规范,比如GB-2312, UTF-8, UNICODE等等,因此要在char和byte之间做转换的话,必须要指定转换所使用的编码规范,
一旦规范写错,转换成的字符串就不是你想要的了。而且几乎无法查错。所以才有这么一句话。
一般在java里都会在InputStream类外面包一层文本格式转换的流类,然后通过外边那层类来操作流本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
- ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
- ¥20 有关区间dp的问题求解
- ¥15 多电路系统共用电源的串扰问题
- ¥15 slam rangenet++配置
- ¥15 有没有研究水声通信方面的帮我改俩matlab代码
- ¥15 ubuntu子系统密码忘记
- ¥15 保护模式-系统加载-段寄存器
- ¥15 电脑桌面设定一个区域禁止鼠标操作
- ¥15 求NPF226060磁芯的详细资料