更方便的监测变量值变化更方便的翻阅当前执行代码所在文件( c6 N L6 s) y
就是设置会稍微麻烦一些。4 x* C9 S/ B, Z% @
步骤 1:安装调试插件/ a/ W& l: n- O3 x6 B
VS code 默认只支持 node.js 语言的调试,其他语言的调试需要安装插件。
/ K! j9 w8 K! T* M
搜索 C++,安装插件。不过要注意的是,插件本身并不具备编译、调试的能力,需要另外使用软件进行编译、调试[1]。
步骤2:配置" [: l9 F9 V, P3 V
调试前需要手动配置launch.json文件指定调试入口,点击 Open Configurations开始配置:
配置VS code配置文件:* r7 ~5 f+ n8 M/ y4 k2 l8 I
- {8 _, _$ W% m( E! R8 u# T! u
- // Use IntelliSense to learn about possible attributes.
- // Hover to view descriptions of existing attributes.
- // For more information, visit: <a href="https://go.microsoft.com/fwlink/?linkid=830387" target="_blank">https://go.microsoft.com/fwlink/?linkid=830387</a>* T" H$ [+ V& ~' _' x
- "version": "0.2.0",1 [- `. G( ~4 {" ~! g% A
- "configurations": [
- {
- "name": "(gdb) Launch",
- "type": "cppdbg",
- "request": "launch",9 q- q8 t1 }1 q. t! I
- "program": "${workspaceFolder}/src/bitcoind",1 P9 M1 v% ^- p6 L$ i- I
- "args": ["-regtest"],2 _# p7 I: J. t2 z9 S
- "stopAtEntry": false,3 P; z8 {6 z* I S( {+ Z7 j
- "cwd": "${workspaceFolder}",
- "environment": [],
- "externalConsole": true,7 a5 h* R& V$ {: E" J
- "MIMode": "gdb",. B7 Q+ k+ E3 s9 J3 S) m
- "setupCommands": [7 v6 `! U7 p6 G0 ]. p& c, p4 }
- {( k; l: a& l. x
- "description": "Enable pretty-printing for gdb",/ ?* v; R4 O0 ^/ n' X
- "text": "-enable-pretty-printing",
- "ignoreFailures": true
- }
- ]
- }9 T8 w7 |1 w) v+ O+ @
- ]
- }
配置文件的路径为 ./vscode/launch.json
json文件中各个参数的含义:" }" `" X3 t, e* W1 \) _
program:程序编译后得到的可执行文件,即调试的入口args:可执行文件的参数,以上图中指定-regtest为例name: 配置的名称,在左侧调试框可以选择使用哪个配置
- _3 ~8 o+ |/ O4 T9 ~7 m! m
步骤 3:编译
调试前需要先将程序编译到上述设置的指定位置,可以在命令行启动编译。也可以通过配置.vscode/tasks.json文件设置任务,在 VS code 内启动编译程序[2][3].
bitcoin core 的编译命令[4],注意添加给 configure 添加参数 --enable-debug[5]:: v: k- j5 {( C5 f/ m; ~
cd bitcoin/5 t! d$ j. s1 c0 y ]( P
./autogen.sh- L* O5 [# b/ E
./configure --disable-wallet --without-gui --without-miniupnpc --enable-debug
make check7 I9 F& z. s5 Y) D$ M
由于在 macOS 环境下编译失败,在 Debian 环境下编译成功了,下面以 Debian 环境示范。
步骤四:开始调试
点击行号左侧设置断点:$ z( @7 t& N9 _- J5 F' k. p/ {/ E
点击左侧调试工具栏的“开始”按钮,或者按 F5 快捷键,开始调试:5 K! G$ _3 H1 c6 T" U9 C* |' z' B
点击屏幕上方的 step into 运行下一步:
20190526更新:& M# D/ \$ d# j+ Y7 K: Z! _
macOS 环境下编译成功了,只是执行失败了。原因是vscode 调试时会在 shell 运行命令:0 x6 N" o5 Y/ ^0 F- u) ~
arch -arch x86_64 '/Users/yushengzhou/.vscode/extensions/ms-vscode.cpptools-0.23.1/debugAdapters/lldb/bin/lldb-launcher' --unix-socket=/tmp/61Ab3Q --arch=x86_64 --working-dir '/Users/yushengzhou/code/bitcoin' --disable-aslr -- '/Users/yushengzhou/code/bitcoin/src/bitcoind' '' ; echo Process exited with status $? ; exit
这个用的是 bash 的语法,而我默认用的是 shell 是 fish。因为语法的不兼容而造成运行失败,只需要将 shell 换成 bash 即可。9 M- L! y; j# @3 \8 Q" x4 @9 i