24 碰到的一个 idea的奇怪的编码问题

2024-05-28 15:38
文章标签 问题 idea 碰到 编码 24 奇怪

本文主要是介绍24 碰到的一个 idea的奇怪的编码问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

以下为日记内容, 实质记录是发生在昨天, 08.09

咦, 现在的文档下载都至少需要 1个积分了吗, 之前的那些免费的文档似乎也被csdn控制成了需要1积分下载了 

--------------------------------------------------

今天 晚上 idea 遇到了一个编码问题 我不太明白, 说一下环境吧
idea 启动程序编码[-Dfile.encoding]默认是 utf-8, 然后 测试程序文件的编码 是gbk, 然后 System.out.println 出来[debug的结果也是一样]的结果为 该字符串的 gbk编码之后 utf-8解码的乱码 "���"
这个倒是正常的瑟, 文件写入以 gbk 写入, 然后 以utf-8读出 乱码, 然后 之后的时候, 我在测试程序配置了一下启动参数 -Dfile.encoding=gbk, 然后 妈的 返现输出 还是乱码 "???"
然后 之后的时候, 我就把 idea的 jvm 配置增加了 -Dfile.encoding=gbk, ## 这时候, 原来是 gbk 的文件, 不知为何idea突然 换成了以 utf-8 加载, 然后 我以gbk编码reload了一下, 正常了, 
然后 继续跑, 然后 发现, 还是 以gbk编码之后 utf-8解码的乱码 "���", 然后 之后 再启动测试程序配置了一下启动参数 -Dfile.encoding=gbk, 然后 还是 "???"


然后 就在我放弃的时候, 我删掉了 idea 的jvm配置 -Dfile.encoding, 然后 删掉了测试程序的 -Dfile.encoding, 然后 跑了一下, 我去 居然又好了, 真是奇怪
然后 我想了一下, 可能存在的原因, 可能是因为 我的项目是 gbk 编码嘛, 然后 但是存在部分文件是 utf-8 编码, 然后 在决策以什么编码编译的时候, 编译器可能以utf-8读取的文件, 但是 为什么测试程序 配置了 -Dfile.encoding=gbk, 然后 读取到的数据 仍然是乱码, 这个 我就不知道了[因为根本与 file.encoding的配置没有关系]
然后  我尝试证实一下这个猜想, 然后 更新了一下 外部的一个文件的编码, 以及 req_dto包下面的一个文件的编码, 更新为 utf-8, 然后 发现, 我的猜想是错的 !


java编译器编码和JVM编码问题?

https://www.zhihu.com/question/30977092/answer/50182545

然后 看了一下 R大的这篇文章, 我觉得问题可能实在 编译器编译的时候的编码, 可能在第一次进来的时候 和最后一次运行的时候, 可能是读取源码文件的时候编码可能不一致吧, 可能前者使用 utf-8读取的源码, 然后 后者以gbk读取的文件, 然后 执行的时候, 因为字节码规范约定的字符串以utf-8存储, 然后 jvm读取字节码的时候 以utf-8读取字符串[偏离了这里的问题之外]
问题的出现的原因
-----
这个 问题, 还得想想, 说不定 可以写出一篇博客, 如果能够重现问题就好了, 
哦, 说一下 问题的出现的吧, 首先是 我创建了一个 train_dto 的包, 然后 吧train相关的 reqdto 拷贝进来了, 文件格式是 utf-8m, 
然后 其余的大部分文件时 gbk, 外围的 test03 还有几个utf-8的文件, 然后 新建了一个 gbk 的 Test27GenerateXYJParamSql, 然后 跑的时候, 就出现了 这个问题,


源码的编码[gbk] - 编译器读取文件的编码
在之前存在乱码问题, 在之后增加 -Dfile.encoding idea配置选项, 然后又删除, 重启之后不存在乱码
源码的编码[utf-8] - 编译器读取文件的编码
吧 Test29OutputChinese 编码变成 utf-8, 然后 输出的结果 为 "浣犲ソ"[utf-8, gbk]
测试程序 源码 gbk, 加上-Dfile.encoding=gbk, 之后 str.getBytes("gbk"), "utf-8") 为 "???" [这个输出不一样, 可能是与System.out的输出编码有关系]
## 哦, 对了, 还有一个 编码是 System.out.println 编码, 但是 不应该是这个, 毕竟 debug 调试的时候, 字符串就已经是 乱码了,

哦, 对了 吧 Test29OutputChinese 编码变成 utf-8, 然后 javac -p 给定的字节码文件, 得到的结果 是"浣犲ソ"的乱码, 然后 文件如果是 gbk编码写出, 则是正常的 "你好", 因此, 可以推测出 javac 的读取源码的编码是 使用的编码是 gbk[也就是 R大回答的如果编译的时候 没有指定-encoding 读取平台默认编码, 我这里的默认编码为 gbk]

--------------------------------------------------
然后 加上 -Dfile.encoding=gbk, 字节码中得到的是正常的 "你好", 然后 str.getBytes("gbk") 得到的是 [-60,  -29,  -70,  -61]
加上 -Dfile.encoding=utf-8, 字节码中得到的是正常的 "你好", 然后 str.getBytes("gbk") 得到的是 [-60,  -29,  -70,  -61]
调试 上面的两个 -Dfile.encoding, 在 StringCoding. decode(byte[] ba, int off, int len) 末尾, 两个得到的结果是一致的 !
然后 看两个字符串包装的 char数组, 发现他们的数据 也是一样的, 然后 这里的输出不一样, 可能是与 System.out 的输出编码有关系[强调了三次]
在上面两个 -Dfile.encoding 调试的时候, 我去 jvm 还崩溃了一次, 在 StringCoding. decode(byte[] ba, int off, int len) 之后
然而 直接 run as 却没事,,. 我去 这是什么情况, 现在 不知为何, 只要 已在 String.class 中打断点, 一下就崩溃了[前几次调试都还行, 后来不知怎么的就挂了],, 不论哪一种 -Dfile.encoding

#
# A fatal error has been detected by the Java Runtime Environment:
#
#  EXCEPTION_ACCESS_VIOLATION (0xc0000005) at pc=0x00000000512142b9, pid=51568, tid=51764
#
# JRE version: Java(TM) SE Runtime Environment (7.0_40-b43) (build 1.7.0_40-b43)
# Java VM: Java HotSpot(TM) 64-Bit Server VM (24.0-b56 mixed mode windows-amd64 compressed oops)
# Problematic frame:
# V  [jvm.dll+0x542b9]
#
# Failed to write core dump. Minidumps are not enabled by default on client versions of Windows
#
# An error report file with more information is saved as:
# D:\Program Files\WorkStations\EclipseWorkStation\HelloWorld03\hs_err_pid51568.log
#
# If you would like to submit a bug report, please visit:
#   http://bugreport.sun.com/bugreport/crash.jsp
#

调试 StringEncoding.encode 的过程中的crsh 日志文件 : http://download.csdn.net/download/u011039332/9928429

今天 又来debug, 结果 还是 crash了, 然后 这里的日志是今天的crash日志, 昨天的被删掉了

 

--------------------------------------------------

对了, 差点忘记了放测试代码, 几句 System.out.println

 

/*** Test28OutputChinese** @author Jerry.X.He <970655147@qq.com>* @version 1.0* @date 8/9/2017 8:43 PM*/
public class Test28OutputChinese {// Test28OutputChinesepublic static void main(String[] args) throws Exception {String str = "你好";System.out.println(str);System.out.println(Charset.defaultCharset());byte[] gbkDecoded = str.getBytes("gbk");for (byte b : gbkDecoded) {System.out.print(b + " ");}System.out.println();String gbkUtf8 = new String(str.getBytes("gbk"), "utf-8");System.out.println(gbkUtf8);
//        info(new String(str.getBytes("gbk"), "ascii"));String utf8Gbk = new String(str.getBytes("utf-8"), "gbk");System.out.println(utf8Gbk);}}

--------------------------------------------------
 

 

 

希望之后能够回过头来真真正正的有头有尾的解释这个问题吧[上面都只是猜测], 哦, 对了 还有这个 crash 的原因

 

refer 

https://www.zhihu.com/question/30977092/answer/50182545

 

这篇关于24 碰到的一个 idea的奇怪的编码问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1010980

相关文章

linux生产者,消费者问题

pthread_cond_wait() :用于阻塞当前线程,等待别的线程使用pthread_cond_signal()或pthread_cond_broadcast来唤醒它。 pthread_cond_wait() 必须与pthread_mutex 配套使用。pthread_cond_wait()函数一进入wait状态就会自动release mutex。当其他线程通过pthread

问题:第一次世界大战的起止时间是 #其他#学习方法#微信

问题:第一次世界大战的起止时间是 A.1913 ~1918 年 B.1913 ~1918 年 C.1914 ~1918 年 D.1914 ~1919 年 参考答案如图所示

2024.6.24 IDEA中文乱码问题(服务器 控制台 TOMcat)实测已解决

1.问题产生原因: 1.文件编码不一致:如果文件的编码方式与IDEA设置的编码方式不一致,就会产生乱码。确保文件和IDEA使用相同的编码,通常是UTF-8。2.IDEA设置问题:检查IDEA的全局编码设置和项目编码设置是否正确。3.终端或控制台编码问题:如果你在终端或控制台看到乱码,可能是终端的编码设置问题。确保终端使用的是支持你的文件的编码方式。 2.解决方案: 1.File -> S

idea lanyu方式激活

访问http://idea.lanyus.com/这个地址。根据提示将0.0.0.0 account.jetbrains.com添加到hosts文件中,hosts文件在C:\Windows\System32\drivers\etc目录下。点击获得注册码即可。

vcpkg安装opencv中的特殊问题记录(无法找到opencv_corexd.dll)

我是按照网上的vcpkg安装opencv方法进行的(比如这篇:从0开始在visual studio上安装opencv(超详细,针对小白)),但是中间出现了一些别人没有遇到的问题,虽然原因没有找到,但是本人给出一些暂时的解决办法: 问题1: 我在安装库命令行使用的是 .\vcpkg.exe install opencv 我的电脑是x64,vcpkg在这条命令后默认下载的也是opencv2:x6

问题-windows-VPN不正确关闭导致网页打不开

为什么会发生这类事情呢? 主要原因是关机之前vpn没有关掉导致的。 至于为什么没关掉vpn会导致网页打不开,我猜测是因为vpn建立的链接没被更改。 正确关掉vpn的时候,会把ip链接断掉,如果你不正确关掉,ip链接没有断掉,此时你vpn又是没启动的,没有域名解析,所以就打不开网站。 你可以在打不开网页的时候,把vpn打开,你会发现网络又可以登录了。 方法一 注意:方法一虽然方便,但是可能会有

IDEA配置Tomcat远程调试

因为不想把本地的Tomcat配置改乱或者多人开发项目想测试,本文主要是记录一下,IDEA使用Tomcat远程调试的配置过程,免得一段时间不去配置到时候忘记(毕竟这次是因为忘了,所以才打算记录的…) 首先在catalina.sh添加以下内容 JAVA_OPTS="-Dcom.sun.management.jmxremote=-Dcom.sun.management.jmxremote.port

vue同页面多路由懒加载-及可能存在问题的解决方式

先上图,再解释 图一是多路由页面,图二是路由文件。从图一可以看出每个router-view对应的name都不一样。从图二可以看出层路由对应的组件加载方式要跟图一中的name相对应,并且图二的路由层在跟图一对应的页面中要加上components层,多一个s结尾,里面的的方法名就是图一路由的name值,里面还可以照样用懒加载的方式。 页面上其他的路由在路由文件中也跟图二是一样的写法。 附送可能存在

vue+elementui--$message提示框被dialog遮罩层挡住问题解决

最近碰到一个先执行this.$message提示内容,然后接着弹出dialog带遮罩层弹框。那么问题来了,message提示框会默认被dialog遮罩层挡住,现在就是要解决这个问题。 由于都是弹框,问题肯定是出在z-index比重问题。由于用$message方式是写在js中而不是写在html中所以不是很好直接去改样式。 不过好在message组件中提供了customClass 属性,我们可以利用

Visual Studio中,MSBUild版本问题

假如项目规定了MSBUild版本,那么在安装完Visual Studio后,假如带的MSBUild版本与项目要求的版本不符合要求,那么可以把需要的MSBUild添加到系统中,然后即可使用。步骤如下:            假如项目需要使用V12的MSBUild,而安装的Visual Studio带的MSBUild版本为V14。 ①到MSDN下载V12 MSBUild包,把V12包解压到目录(