通常用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