更方便的监测变量值变化更方便的翻阅当前执行代码所在文件
就是设置会稍微麻烦一些。
步骤 1:安装调试插件
VS code 默认只支持 node.js 语言的调试,其他语言的调试需要安装插件。- P7 i [' z* u; ]- M$ m; k+ Q
搜索 C++,安装插件。不过要注意的是,插件本身并不具备编译、调试的能力,需要另外使用软件进行编译、调试[1]。% S. d3 u; Q4 k& u& u+ _
# j. x- ?8 l4 n8 X9 j5 ~
步骤2:配置
调试前需要手动配置launch.json文件指定调试入口,点击 Open Configurations开始配置:
配置VS code配置文件:
- {1 I# C0 R, |6 S. s e
- // 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>
- "version": "0.2.0",4 _* a' _0 r* T6 l! m. `8 \
- "configurations": [+ u) p; T* C; p5 K/ y* r8 n
- {6 _! _+ T4 t8 N, l4 N& t6 p
- "name": "(gdb) Launch",5 z p* o/ {* I* N x
- "type": "cppdbg",
- "request": "launch",
- "program": "${workspaceFolder}/src/bitcoind",
- "args": ["-regtest"],
- "stopAtEntry": false,4 I% X" V. o" c' N
- "cwd": "${workspaceFolder}",
- "environment": [],
- "externalConsole": true,% Y( `3 ^% x) Q: ]+ O# }$ d
- "MIMode": "gdb",: N9 F" G) X( T' S4 M; j5 P0 M' l
- "setupCommands": [: U! w8 G7 ~' _* [. Z
- {
- "description": "Enable pretty-printing for gdb",
- "text": "-enable-pretty-printing",5 H; R% b% |+ t; g; |/ w; s
- "ignoreFailures": true; _3 Q) d1 S( g o; r6 ]9 @
- }5 P; b* o4 f) ^! Y) v
- ]8 H; ^( [" b) ~4 G7 I# ~- B
- }' `6 f* e+ l) G8 ?: h% j% N8 ~
- ]% p3 ~/ P5 e R! C$ U
- }
配置文件的路径为 ./vscode/launch.json
json文件中各个参数的含义:
program:程序编译后得到的可执行文件,即调试的入口args:可执行文件的参数,以上图中指定-regtest为例name: 配置的名称,在左侧调试框可以选择使用哪个配置9 I1 ^& [2 ]" H- g% P
步骤 3:编译# [3 A8 b1 }/ q2 h5 ~
调试前需要先将程序编译到上述设置的指定位置,可以在命令行启动编译。也可以通过配置.vscode/tasks.json文件设置任务,在 VS code 内启动编译程序[2][3]. A. o x5 z4 p/ ?0 U
bitcoin core 的编译命令[4],注意添加给 configure 添加参数 --enable-debug[5]:; p4 C7 O N3 ]0 W
cd bitcoin/' ?3 @$ E2 k) |7 V2 l/ |! Z8 W
./autogen.sh
./configure --disable-wallet --without-gui --without-miniupnpc --enable-debug: t4 l. r" m3 W; m
make check
由于在 macOS 环境下编译失败,在 Debian 环境下编译成功了,下面以 Debian 环境示范。, V$ K& G* I0 z# z3 u* D# D
步骤四:开始调试- a# U1 a- {; e8 Y+ g6 q
点击行号左侧设置断点:, O f" L/ e* [' i0 F' i% ~
点击左侧调试工具栏的“开始”按钮,或者按 F5 快捷键,开始调试:
4 _5 g% E1 r) S
点击屏幕上方的 step into 运行下一步:
20190526更新:; C* Z& i2 h0 h$ v4 I+ S' K b1 y% a
macOS 环境下编译成功了,只是执行失败了。原因是vscode 调试时会在 shell 运行命令:1 Y; u- i' r1 o3 Y& }
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. i8 V" ~; e0 W9 \- `4 L q/ q6 N7 ~
这个用的是 bash 的语法,而我默认用的是 shell 是 fish。因为语法的不兼容而造成运行失败,只需要将 shell 换成 bash 即可。
& x1 Q h G2 F4 M5 a$ L6 @8 Z, X