在 Linux 下使用 C++ 进行日志记录,有多种方法和库可供选择。以下是几种常用的方法:
<iostream>
和文件流 <fstream>
这是最基本的方法,通过 C++ 标准库中的输入输出流来实现日志记录。
#include <iostream>
#include <fstream>
#include <string>
#include <ctime>
void logMessage(const std::string& message) {
std::ofstream logFile("app.log", std::ios::app); // 打开日志文件,追加模式
if (logFile.is_open()) {
time_t now = time(0);
char* dt = ctime(&now);
logFile << "[" << dt << "] " << message << std::endl;
logFile.close();
} else {
std::cerr << "无法打开日志文件" << std::endl;
}
}
int main() {
logMessage("程序启动");
// ... 程序逻辑 ...
logMessage("程序结束");
return 0;
}
spdlog 是一个非常流行且高效的 C++ 日志库,支持异步日志记录、多种日志格式和目标(控制台、文件等)。
安装:
可以通过包管理器安装,例如在 Ubuntu 上:
sudo apt-get install libspdlog-dev
或者从 GitHub 克隆并编译:
git clone https://github.com/gabime/spdlog.git
cd spdlog
mkdir build && cd build
cmake ..
make
sudo make install
示例代码:
#include "spdlog/spdlog.h"
#include "spdlog/sinks/basic_file_sink.h"
int main() {
// 创建一个基本文件日志记录器,日志文件名为logs/basic.txt
auto logger = spdlog::basic_logger_mt("basic_logger", "logs/basic.txt");
// 设置日志级别
logger->set_level(spdlog::level::info);
// 记录日志
logger->info("欢迎使用 spdlog!");
logger->warn("小心!这是一条警告信息。");
logger->error("发生错误!");
return 0;
}
log4cpp 是另一个功能丰富的 C++ 日志库,受 Java 的 log4j 启发。
安装:
在 Ubuntu 上:
sudo apt-get install liblog4cpp5-dev
示例代码:
#include <log4cpp/Category.hh>
#include <log4cpp/FileAppender.hh>
#include <log4cpp/OstreamAppender.hh>
#include <log4cpp/BasicLayout.hh>
int main() {
// 创建布局
log4cpp::BasicLayout* layout = new log4cpp::BasicLayout();
// 创建文件附加器
log4cpp::FileAppender* fileAppender = new log4cpp::FileAppender("default", "application.log");
fileAppender->setLayout(layout);
// 创建类别并设置附加器
log4cpp::Category& root = log4cpp::Category::getRoot();
root.addAppender(fileAppender);
root.setPriority(log4cpp::Priority::INFO);
// 记录日志
root.info("欢迎使用 log4cpp!");
root.warn("小心!这是一条警告信息。");
root.error("发生错误!");
// 清理资源
delete layout;
delete fileAppender;
return 0;
}
对于需要与系统日志集成的应用,可以使用 syslog。C++ 中可以通过 syslog.h
来实现。
示例代码:
#include <syslog.h>
#include <string>
#include <ctime>
void logToSyslog(const std::string& message) {
openlog("myapp", LOG_PID | LOG_CONS, LOG_USER);
time_t now = time(nullptr);
char buf[80];
strftime(buf, sizeof(buf), "%Y-%m-%d %H:%M:%S", localtime(&now));
syslog(LOG_INFO, "[%s] %s", buf, message.c_str());
closelog();
}
int main() {
logToSyslog("程序启动");
// ... 程序逻辑 ...
logToSyslog("程序结束");
return 0;
}
Boost.Log 是 Boost 库中的一个强大日志组件,支持丰富的功能和灵活的配置。
安装:
需要先安装 Boost 库,具体步骤可以参考 Boost 官方文档。
示例代码:
#include <boost/log/core.hpp>
#include <boost/log/trivial.hpp>
#include <boost/log/expressions.hpp>
#include <boost/log/sinks/text_file_backend.hpp>
#include <boost/log/utility/setup/file.hpp>
#include <boost/log/utility/setup/console.hpp>
namespace logging = boost::log;
namespace src = boost::log::sources;
namespace sinks = boost::log::sinks;
namespace expr = boost::log::expressions;
void init_logging() {
// 初始化文件后端
typedef sinks::text_file_backend< sinks::file::rotation_size<10*1024*1024>, // 每个文件最大10MB
sinks::file::time_based_rotation >
file_backend;
// 创建格式化器
typedef sinks::synchronous_sink<file_backend> sink;
boost::shared_ptr<sink> sink_ptr(new sink);
file_backend* backend = sink_ptr->locked_backend();
backend->add_stream(boost::make_shared<std::ofstream>("application.log"));
backend->set_formatter(
expr::stream
<< expr::format_date_time<boost::posix_time::ptime>("TimeStamp", "%Y-%m-%d %H:%M:%S")
<< " [" << logging::trivial::severity << "] " << expr::smessage
);
// 添加到核心
logging::core::get()->add_sink(sink_ptr);
// 设置日志级别
logging::core::get()->set_filter(
logging::trivial::severity >= logging::trivial::info
);
// 添加控制台输出
logging::core::get()->add_common_attributes();
}
int main() {
init_logging();
BOOST_LOG_TRIVIAL(info) << "欢迎使用 Boost.Log!";
BOOST_LOG_TRIVIAL(warning) << "小心!这是一条警告信息。";
BOOST_LOG_TRIVIAL(error) << "发生错误!";
return 0;
}
根据项目需求和复杂度,可以选择不同的日志记录方法:
<iostream>
和 <fstream>
。syslog
。其中,spdlog 因其高性能和易用性,在现代 C++ 项目中非常受欢迎。建议根据具体需求选择合适的工具,并参考相应的文档进行更深入的使用和配置。