Electron 调试
有许多不同的方法来调试 Electron 中的问题和错误,其中许多方法是特定于平台的。
下面概述了一些更常见的方法。
通用调试
Chromium 包含日志记录宏,可以通过在 C++ 和 Objective-C++ 中将信息打印到控制台来辅助调试。
您可以使用它来打印变量值、函数名称和行号等信息。
一些例子
LOG(INFO) << "bitmap.width(): " << bitmap.width();
LOG(INFO, bitmap.width() > 10) << "bitmap.width() is greater than 10!";
还有不同的日志记录严重级别:INFO
、WARN
和 ERROR
。
有关更多信息和示例,请参阅 Chromium 源代码树中的 logging.h。
打印堆栈跟踪
Chromium 包含一个助手,可以将堆栈跟踪打印到控制台,而不会中断程序。
#include "base/debug/stack_trace.h"
...
base::debug::StackTrace().Print();
这将允许您观察调用链并识别潜在的问题区域。
断点调试
请注意,这将显着增加构建的大小,占用大约 50G 的磁盘空间
将以下文件写入 electron/.git/info/exclude/debug.gn
import("//electron/build/args/testing.gn")
is_debug = true
symbol_level = 2
forbid_non_component_debug_builds = false
然后执行
$ gn gen out/Debug --args="import(\"//electron/.git/info/exclude/debug.gn\") $GN_EXTRA_ARGS"
$ ninja -C out/Debug electron
现在您可以使用 LLDB
进行断点调试。
平台特定调试
使用符号服务器调试
调试符号使您可以拥有更好的调试会话。它们包含有关可执行文件和动态库中包含的函数的信息,并为您提供信息以获取清晰的调用堆栈。符号服务器允许调试器自动加载正确的符号、二进制文件和源代码,而无需强制用户下载大型调试文件。
有关如何为 Electron 设置符号服务器的更多信息,请参阅 使用符号服务器调试。