1

我正在使用 spdlog 登录 Visual Studio 项目。我在 Qt creator 中使用了相同的项目,然后 spdlog 日志记录不输出任何内容。但 std::cout 仍然有效并打印到 Qt 创建者的应用程序输出窗口。

std::vector<spdlog::sink_ptr> sinks;
sinks.push_back(std::make_shared<spdlog::sinks::stdout_color_sink_mt>());
sinks.push_back(std::make_shared<spdlog::sinks::basic_file_sink_mt>("multisink.txt", true));
auto appLogger = std::make_shared<spdlog::logger>("appLogger", begin(sinks), end(sinks));
appLogger->set_level(spdlog::level::debug);
spdlog::register_logger(appLogger);
spdlog::flush_on(spdlog::level::debug);    
appLogger->warn("this should appear in both console and file");
4

2 回答 2

1

是的,应用程序输出不输出 spdlogs。但是,我设法通过以下步骤输出到终端。

  1. 转到 Projects,然后选择 Run configuration for selected kit
  2. 在运行设置中,选中“在终端中运行”选项
  3. 接下来,在 Project pro 文件中将控制台添加到 CONFIG
  4. 清理项目
  5. 构建并运行。

如果这些步骤没有帮助,您可以删除整个构建目录并再次运行这些步骤。

于 2018-09-13T06:51:20.047 回答
1

我遇到了同样的问题,我可以让日志消息出现在应用程序输出选项卡中的唯一方法是使用 msvc 记录器。

auto sink   = std::make_shared<spdlog::sinks::msvc_sink_mt>();
auto logger = std::make_shared<spdlog::logger>("msvc_logger", sink);

这个记录器的另一面是它不会打印到控制台/终端。

要使用相同的记录器写入应用程序输出和控制台,您可以创建一个分布式接收器,如下所示:

auto console_sink = std::make_shared<spdlog::sinks::stdout_color_sink_mt>();
auto msvc_sink    = std::make_shared<spdlog::sinks::msvc_sink_mt>();
auto dist_sink    = std::make_shared<spdlog::sinks::dist_sink_st>();
dist_sink->add_sink(msvc_sink);
dist_sink->add_sink(console_sink);
auto logger = std::make_shared<spdlog::logger>("multi_sink", dist_sink)
logger->info("testing multiple sinks");
于 2018-10-11T19:03:24.540 回答