程序员专属暗语:
上联:手持两把锟斤拷,口中疾呼烫烫烫。
下联:脚踏千朵屯屯屯,笑看万物锘锘锘。
按照惯例,一图解千愁:
一、锟斤拷
UTF-8字符集,当出现目前无法显示的字符时,用一个占位符号0x ef bf bd(3Bytes大小)填充。
当出现一连串的无法显示字符时,会被填充为0x ef bf bd ef bf bd ……
当把这个UTF-8编码方式的数据以GBK编码方式打开时,就会出现问题了。
因为GBK是以2Bytes大小进行解码的,所以上述的(0x ef bf bd ef bf bd ……)就会解码为:
0x ef bf —— 锟 (GBK解码)
0x bd ef —— 斤(GBK解码)
0x bf bd —— 拷(GBK解码)
二、烫、屯
这个就不是字符集的问题了。
这要先说微软VC编码器的设置了,当进入debug模式时,会有以下情况:
1、未初始化栈区内存:
会被编译器设置为0xcc,其实也是对应着INT3软中断指令的机器码:0xcccc…
0x cc cc cc cc —— 烫烫烫烫 (GBK解码)
2、未初始化堆区内存:
会被编译器设置为0xcd
0x cd cd cd cd —— 屯屯屯屯 (GBK解码)
3、未初始化的堆内存前后会有一个4B的围栏:
围栏:0x fd fd fd fd
4、销毁的堆区内存:
会被设置为:0x dd dd dd dd
三、锘锘锘
(我不知道了,目前没见过,见到了再补充)
今天的文章打印文件出现乱码是怎么回事_打印文件出现乱码是怎么回事分享到此就结束了,感谢您的阅读。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/81479.html