更方便的监测变量值变化更方便的翻阅当前执行代码所在文件
就是设置会稍微麻烦一些。( S5 X* e k+ {6 k/ r) f
步骤 1:安装调试插件
VS code 默认只支持 node.js 语言的调试,其他语言的调试需要安装插件。
2 N- m" [/ M+ j' V* J ~& q8 H
搜索 C++,安装插件。不过要注意的是,插件本身并不具备编译、调试的能力,需要另外使用软件进行编译、调试[1]。! n/ d2 S# y7 @. `8 u) e
步骤2:配置# G. w; M; F, x- d2 [9 B7 a L
调试前需要手动配置launch.json文件指定调试入口,点击 Open Configurations开始配置:
配置VS code配置文件:/ y! y5 Z6 i$ l* D
- {( K; i4 @+ c$ ]: a7 r! s* i- F+ G: Z
- // Use IntelliSense to learn about possible attributes.6 w$ _. D# M# i8 `, L, }# `+ `
- // 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",
- "configurations": [
- {. Q. b( L# X i5 E
- "name": "(gdb) Launch",7 u, u4 _% O0 T, q0 ^
- "type": "cppdbg",2 g* R; l8 s( N# p$ F; R/ S5 [# ~
- "request": "launch",* e+ ?2 H5 l n6 V6 `* s
- "program": "${workspaceFolder}/src/bitcoind",1 s# B( U, `3 c
- "args": ["-regtest"],+ L4 n2 _9 P- |( m( ]$ k, k
- "stopAtEntry": false,
- "cwd": "${workspaceFolder}",
- "environment": [],
- "externalConsole": true,& u% e! Y) g, R+ A
- "MIMode": "gdb",
- "setupCommands": [
- {/ Z7 R# h" ~) k9 M5 R
- "description": "Enable pretty-printing for gdb",4 Z9 A) Z2 I. W; j+ M; b
- "text": "-enable-pretty-printing",
- "ignoreFailures": true; J+ ~2 @! _! W9 _
- }
- ]
- }
- ]3 @6 f. J0 L$ d) d7 b; K6 A
- }
配置文件的路径为 ./vscode/launch.json
json文件中各个参数的含义:& Q# [) Q5 F% F1 H; R- B- N, h, {
program:程序编译后得到的可执行文件,即调试的入口args:可执行文件的参数,以上图中指定-regtest为例name: 配置的名称,在左侧调试框可以选择使用哪个配置
步骤 3:编译
调试前需要先将程序编译到上述设置的指定位置,可以在命令行启动编译。也可以通过配置.vscode/tasks.json文件设置任务,在 VS code 内启动编译程序[2][3].
bitcoin core 的编译命令[4],注意添加给 configure 添加参数 --enable-debug[5]: c7 [2 J" O5 J$ Y8 ^
cd bitcoin/) s) z9 ] e6 P$ _5 E9 D! P
./autogen.sh
./configure --disable-wallet --without-gui --without-miniupnpc --enable-debug
make check4 i1 J% v. d8 q9 T7 P
由于在 macOS 环境下编译失败,在 Debian 环境下编译成功了,下面以 Debian 环境示范。9 S: V0 a: \' W. c; f& r; U: g
步骤四:开始调试
点击行号左侧设置断点:$ ~+ R7 G8 R& J: `- r5 @
点击左侧调试工具栏的“开始”按钮,或者按 F5 快捷键,开始调试:& t% `7 y* m: `% X1 _. }
: U6 v, [6 L. c
点击屏幕上方的 step into 运行下一步:) J0 k) l5 z( v% {( n' K
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 即可。! Q7 }" e+ N2 V0 p1 D- P' p6 ^
( Q. D$ D7 [) R X* x- ~- I9 w2 G( I& w