解决GDB tui模式时日文乱码的问题
目录
- 解决GDB tui模式时日文乱码的问题
- RHEL5的画风
- RHEL6的画风
- RHEL7的画风
- 解决之道
- 顺便提一下
解决GDB tui模式时日文乱码的问题
自从升级了RHEL的版本,gdb tui模式调试程序时一直被乱码的问题困扰。一顿搜索猛如虎也解决不了问题。
就陷入了隔一段时间就搜一搜/瞎搞搞,无果,又过一段时间……的轮回。
先来个栗子:
$ cat hello.c
#include
int main(int argc, char *argv[])
{// 挨拶するprintf("お早うございます~\n");return 0;
}
RHEL5的画风
用RHEL5的时候,画风是这样的,还八错
+--hello.c-----------------------------------------------+|3 { ||4 // 挨拶する |>|5 printf("お早うございます~\n"); ||6 return 0; ||7 } ||8 |+--------------------------------------------------------+
native process 10432 In: main L5 PC: 0x4004c3
(gdb)
# 当前OS版本是这样的
$ cat /etc/redhat-release
Red Hat Enterprise Linux Server release 5.9 (Tikanga)
# 关于编码设置这块,terminal,环境变量和source编码都是eucJP
$ echo $LANG
ja_JP.eucJP
# terminal下日文显示莫的问题
$ grep 'print' hello.cprintf("お早うございます~\n");
$
RHEL6的画风
用RHEL6的时候,画风依然坚挺,美着捏
+--./hello.c----------------------------------------------+|3 { ||4 // 挨拶する |>|5 printf("お早うございます~\n"); ||6 return 0; ||7 } ||8 |+---------------------------------------------------------+
child process 26669 In: main Line: 5 PC: 0x4004d3
(gdb)
# OS版本像这样
$ cat /etc/redhat-release
Red Hat Enterprise Linux Server release 6.7 (Santiago)
# 关于编码设置这块,Terminal,环境变量和Source编码都是eucJP
$ echo $LANG
ja_JP.eucJP
# terminal下日文显示也是莫的问题
$ grep 'print' hello.cprintf("お早うございます~\n");
$
RHEL7的画风
用上RHEL7的时候,就垮掉了,哪尼~~!!
+--hello.c----------------------------------------+|3 { ||4 // M-0M-'M-;M-"M-$M-9M-$M-k |>|5 printf("M-$M-*M-AM-aM-$M-&M-$M-4M-$M-||6 return 0; ||7 } ||8 |+-------------------------------------------------+
In: main Line: 5 PC: 0x40052c
(gdb)
# OS版本像这样
$ cat /etc/redhat-release
Red Hat Enterprise Linux Server release 7.6 (Maipo)
# 关于编码设置这块,Terminal,环境变量和Source编码都是eucJP
$ echo $LANG
ja_JP.eucJP
# terminal下日文显示依旧莫的问题,不过tui就惨了
$ grep 'print' hello.cprintf("お早うございます~\n");
$
解决之道
这个方法是试出来的,原理不懂,就是无视所有的eucJP设置,启动gdb时强行指定UTF-8!
让我自己来瞎猜猜原因的话:可能新版的gdb内部用了新版的python啥的强制了哪里utf-8。反正我记得我自己编译python的source时如果不使用utf-8 locale编译就会报错。
总之能显示了,结果如下:
# 不好意思,我这是csh,如果是bash,可以省略env
$ env LANG=UTF-8 gdb ./hello
(gdb) start
:<省略部分输出>argv=0x7fffffffe068) at hello.c:5
5 printf("お早うございます~\n");
Missing separate debuginfos, use: debuginfo-install glibc-2.17-260.el7.x86_64
# 设一下边框类型方便等一下拷贝内容
(gdb) set tui border-kind ascii
然后就准备见证奇迹
Ctrl+X Ctrl+A
将将将将~
+--hello.c----------------------------------------+|3 { ||4 // 挨拶する |>|5 printf("お早うございます~\n"); ||6 return 0; ||7 } ||8 |+-------------------------------------------------+
In: main Line: 5 PC: 0x40052c
(gdb)
完美
后面可以不用看了。
顺便提一下
其实也并非完美,因为窗口里面显示得好了,自己想打印个字符串时就惨了。
+--hello.c----------------------------------------------------------+|1 #include | |2 int main(int argc, char *argv[]) ||3 { ||4 // 挨拶する |>|5 printf("お早うございます~\n"); ||6 return 0; ||7 } ||8 ||9 |+-------------------------------------------------------------------+
child process 129475 In: main Line: 5 PC: 0x40052c
(gdb) p "お早う"
$8 = "\244\252\301\341\244\246"
(gdb)
另外,gdb里面可以进行三个charset设置,看了文档和例子,MS也和本问题的场景无关。设置了也没啥用。
本文来自互联网用户投稿,文章观点仅代表作者本人,不代表本站立场,不承担相关法律责任。如若转载,请注明出处。 如若内容造成侵权/违法违规/事实不符,请点击【内容举报】进行投诉反馈!
