溫馨提示×

C++程序在Linux上如何進行日志記錄

小樊
41
2025-09-25 19:26:22
欄目: 編程語言

在Linux上,C++程序可以使用多種方法進行日志記錄。以下是一些常用的日志庫和工具:

1. 使用標準庫

C++標準庫本身并沒有提供日志記錄功能,但你可以使用文件流(std::ofstream)來寫入日志文件。

#include <fstream>
#include <iostream>
#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 << "Unable to open log file" << std::endl;
    }
}

int main() {
    logMessage("This is a log message.");
    return 0;
}

2. 使用第三方日志庫

a. Boost.Log

Boost.Log是一個功能強大的日志庫,提供了豐富的日志記錄功能。

#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 initLogging() {
    // 添加文件日志后端
    typedef sinks::text_file_backend< sinks::file::rotation_size<10*1024*1024>, sinks::file::time_based_rotation >
        file_backend;
    file_backend backend;
    backend.add_file("app.log");
    backend.auto_flush(true);

    // 添加控制臺日志后端
    typedef sinks::synchronous_sink< sinks::text_ostream_backend< sinks::text_ostream_backend::stream_type& > >
        text_sink;
    text_sink sink(std::cout);
    sink.backends.push_back(backend);

    // 設置日志格式
    expr::stream< expr::keyword::tag< "Severity" >, expr::keyword::tag< "Message" > >
        formatter = expr::stream
            << "[" << expr::attr< std::string >("Severity") << "] "
            << expr::attr< std::string >("Message");
    sink.set_formatter(formatter);

    // 添加日志屬性
    logging::add_common_attributes();

    // 注冊日志記錄器
    logging::core::get()->add_sink(sink);
}

int main() {
    initLogging();
    BOOST_LOG_TRIVIAL(info) << "This is an info message.";
    BOOST_LOG_TRIVIAL(warning) << "This is a warning message.";
    BOOST_LOG_TRIVIAL(error) << "This is an error message.";
    return 0;
}

b. spdlog

spdlog是一個非??焖偾乙子谑褂玫娜罩編?。

#include "spdlog/spdlog.h"
#include "spdlog/sinks/stdout_color_sinks.h"
#include "spdlog/sinks/basic_file_sink.h"

int main() {
    // 創建控制臺日志記錄器
    auto console_sink = std::make_shared<spdlog::sinks::stdout_color_sink_mt>();
    console_sink->set_pattern("[%Y-%m-%d %H:%M:%S] [%l] %v");
    spdlog::register_logger(console_sink);

    // 創建文件日志記錄器
    auto file_sink = std::make_shared<spdlog::sinks::basic_file_sink_mt>("app.log", true);
    file_sink->set_pattern("[%Y-%m-%d %H:%M:%S] [%l] %v");
    spdlog::register_logger(file_sink);

    // 獲取日志記錄器
    auto logger = spdlog::get("console");
    logger->info("This is an info message.");
    logger->warn("This is a warning message.");
    logger->error("This is an error message.");

    return 0;
}

3. 使用系統日志

Linux系統提供了syslog服務,你可以使用syslog庫來記錄日志。

#include <syslog.h>
#include <iostream>
#include <string>

void logMessage(const std::string& message) {
    openlog("myapp", LOG_PID | LOG_CONS, LOG_USER);
    syslog(LOG_INFO, "%s", message.c_str());
    closelog();
}

int main() {
    logMessage("This is a log message.");
    return 0;
}

總結

選擇哪種方法取決于你的需求。如果你需要簡單的日志記錄功能,使用標準庫或系統日志可能就足夠了。如果你需要更高級的功能(如日志級別、格式化、多線程支持等),那么使用第三方日志庫(如Boost.Log或spdlog)會更好。

0
亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女