关于JAVA底层编码和输出中文乱码问题

众所周知,Java的特点是跨平台性

说着不屑一顾,谁不明白Java跨平台?我当时就是这样一种心态,可当我简单的使用一个FileInputStream时,读出来一堆乱码。如图所示:

关于JAVA底层编码和输出中文乱码问题

 关于JAVA底层编码和输出中文乱码问题

明明是最简单的读取然后输出,怎么这都能出错?

其实这一切都是Java底层编码惹的祸。

编码

Java是一个跨平台的高级程序编程语言。这个跨平台性怎么实现的呢?

首先为什么能在每个平台运行,首先归功于Java JDK。

JDK是java运行时环境而JDK是java开发工具包,JDK包含JRE

JDK:java development kit (java开发工具),JDK 是用于开发 Java 程序的最小环境。

JRE:java runtime environment (java运行时环境),是提供给 Java 程序运行的最小环境。

JRE包含了java虚拟机JVM、java基础类库以及一些核心文件。是使用java语言编写的程序运行所需要的软件环境,是提供给想运行java程序的用户使用的。JDK是程序员使用java语言编写java程序所需的开发工具包,是提供给程序员使用的。运行java程序只需安装JRE。如果需要编写java程序,需要安装JDK。 

第一步:

还什么第一步第二步,谁还看这么多?写的越多越没人看!

话不多说,上图!

关于JAVA底层编码和输出中文乱码问题

这什么跟什么啊?这不是基础吗谁不知道?

客官先不要走。

我再来一张图

 关于JAVA底层编码和输出中文乱码问题

看到这大概就明白跨平台性是怎么来的了。

中文乱码问题解决

打开我的文件,查看编码

关于JAVA底层编码和输出中文乱码问题

 我的系统默认以UTF-8形式进行编码。

好的,假设我在这个记事本(.txt)里面敲的字二进制如下:

00000000000000000000000000000000000000000000000000(瞎鸡。。。。  瞎敲的)

然后这属于UTF-8格式,但是我java认得他吗?认得个屁,我用我的ANSI读取文件的用UTF-8编码的数据,你觉得能不出错吗。上面这个二进制在UTF-8是那么几个字,在ANSI里那就不是啦。所以,我把我记事本改为:

关于JAVA底层编码和输出中文乱码问题

然后

关于JAVA底层编码和输出中文乱码问题

看,这不就解决了吗?

学会从底层角度思考为什么出现这个问题。

总结

1、不论自己用哪个编辑器来编写或者作为cv工程师写出来的java源代码,都要在javac编译之前确定编码格式。

2、确定javac解码格式和源文件编码格式一致或者兼容。

3、记事本自己乱敲的编码格式可能和你java编码格式一致或不兼容!


以上都是我搜了很多资料以后自己总结的,希望对你们有所帮助。希望你们能给我个小小的赞QAQ

有错误欢迎评论提出!我会改进的!

上一篇:Java中throws与throw的区别


下一篇:java基础-泛型