更方便的监测变量值变化更方便的翻阅当前执行代码所在文件
就是设置会稍微麻烦一些。% v! S: C' R; K2 [- L% I3 v- N7 p
步骤 1:安装调试插件
VS code 默认只支持 node.js 语言的调试,其他语言的调试需要安装插件。3 J+ E8 W; {, R
搜索 C++,安装插件。不过要注意的是,插件本身并不具备编译、调试的能力,需要另外使用软件进行编译、调试[1]。- M$ x( ~: b. o8 Z0 G _
步骤2:配置: c1 W$ |2 l* k, p1 m8 ^* [
调试前需要手动配置launch.json文件指定调试入口,点击 Open Configurations开始配置:! J+ P: s$ W4 G
8 U D, s; _- i3 @ s
配置VS code配置文件:
- {& V+ {" X) b. D9 T7 ~" n* a
- // Use IntelliSense to learn about possible attributes.8 l ], [- l3 _7 A- n' h
- // Hover to view descriptions of existing attributes.4 i1 e7 W5 X. t6 t
- // For more information, visit: <a href="https://go.microsoft.com/fwlink/?linkid=830387" target="_blank">https://go.microsoft.com/fwlink/?linkid=830387</a>0 G$ q7 O+ Z8 B" @4 C
- "version": "0.2.0",
- "configurations": [6 B; \5 Z4 H9 F1 o0 Y
- {% r8 L5 @/ c$ P# T n6 {
- "name": "(gdb) Launch",
- "type": "cppdbg",
- "request": "launch",1 V' J4 t8 N/ r* M" x1 `
- "program": "${workspaceFolder}/src/bitcoind",3 O, j8 H1 M# `8 d, j V6 B
- "args": ["-regtest"]," q- P7 ^# {3 S3 B* o0 \0 {
- "stopAtEntry": false,
- "cwd": "${workspaceFolder}",
- "environment": [],8 P v; Y& M. w" A- X% \* n% e
- "externalConsole": true,& B5 h+ v; R3 c7 B5 m% [
- "MIMode": "gdb",4 j( R g; h9 o
- "setupCommands": [
- {
- "description": "Enable pretty-printing for gdb",$ ?& e6 D6 ], a9 J' n3 [
- "text": "-enable-pretty-printing",5 p% |! t ^( O7 l- `
- "ignoreFailures": true8 T: g# m/ d' m' J8 K+ a* H
- }0 y2 X% Z( V9 B9 v
- ]/ z4 a8 y: C% v8 {7 T K1 ~
- }- I, w4 s7 g1 S. u
- ]3 L1 Z; U; r: m0 L4 ]2 S
- }
配置文件的路径为 ./vscode/launch.json
json文件中各个参数的含义:
program:程序编译后得到的可执行文件,即调试的入口args:可执行文件的参数,以上图中指定-regtest为例name: 配置的名称,在左侧调试框可以选择使用哪个配置
步骤 3:编译
调试前需要先将程序编译到上述设置的指定位置,可以在命令行启动编译。也可以通过配置.vscode/tasks.json文件设置任务,在 VS code 内启动编译程序[2][3].
bitcoin core 的编译命令[4],注意添加给 configure 添加参数 --enable-debug[5]:
cd bitcoin/
./autogen.sh
./configure --disable-wallet --without-gui --without-miniupnpc --enable-debug" x0 ]) u% s) n
make check
由于在 macOS 环境下编译失败,在 Debian 环境下编译成功了,下面以 Debian 环境示范。( M; Y, b7 v. A
步骤四:开始调试
点击行号左侧设置断点:
5 q9 W$ o/ U# X, v
点击左侧调试工具栏的“开始”按钮,或者按 F5 快捷键,开始调试:* N# v* Y3 c$ Z! [/ q9 ~4 U
4 ^1 u @/ L( m1 ~/ @7 `
点击屏幕上方的 step into 运行下一步:0 B# s6 i8 o1 @ _& T) ]' w
20190526更新:
macOS 环境下编译成功了,只是执行失败了。原因是vscode 调试时会在 shell 运行命令:
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 即可。