如何使用lldb/gdb调试Nim程序

通常用nim写程序基本都用echo, repr等命令简单调试, 相信你们也会须要高级调试的时候, 因此在这里介绍如何使用lldb或gdb调试nim程序.c++

首先输入代码保存test.nim.bash

#test.nim
echo "Hello World"
var x = 10
echo "Value of x: ", x

而后打开终端..net

$nim c --debugger:native test.nim #用nim编译出带调试内容的程序

$lldb ./test #或者gdb ./test
(lldb)b test.nim:2
(lldb)run #运行后会断到 x = 10 这行
(lldb)n #运行到下一行 echo ...
(lldb)p x_95008 #查看x的值,为何是x_95008等会再说
$0 = 10
(lldb)p x_95008 = 666 #改变x的值
$1 = 666
(lldb)c
Value of x: 666
(lldb)q #y 退出调试器

代码里的变量明明是x为何变成x_95008了呢? 并且这个数字我是怎么知道的?debug

这个疑问首先要了解nim的编译过程是怎样, nim编译文件首先会把nim代码转成c/c++/objc代码放到同目录的nimcache目录里, 而后再交给相关的编译器编译, 因此这个变量真实的名字就是在./nimcache/test.c这个文件里.调试

//./nimcache/test.c

#line 1 "/Users/xxx/nimcache/test.nim"
	nimln(1, "test.nim");	printf("%s\012", ((NimStringDesc*) &TMP140)? (((NimStringDesc*) &TMP140))->data:"nil");
#line 2 "/Users/xxx/nimcache/test.nim"
	nimln(2, "test.nim");	x_95008 = ((NI) 10);
#line 3 "/Users/xxx/nimcache/test.nim"
	nimln(3, "test.nim");
#line 3 "/Users/xxx/nimcache/test.nim"
	LOC1 = 0;	LOC1 = nimIntToStr(x_95008);	printf("%s%s\012", ((NimStringDesc*) &TMP141)? (((NimStringDesc*) &TMP141))->data:"nil", LOC1? (LOC1)->data:"nil");	popFrame();}

这些内容都在test.c文件最下面, line其实就是test.nim文件上的代码行, 相同的x_95008就是那个x的真实变量名了, 更多的操做方法你们能够了解lldb/gdb的使用.code

参考资料:Debugging nimblog

相关文章
相关标签/搜索