宏和模板中的可变函数

variadic functions in macro and templates

本文关键字:函数      更新时间:2023-10-16

我试图创建一个宏,调用一个使用模板的可变函数。我使用以下代码,但链接器无法解析对宏的调用。。。

此代码是Logger类的一部分:

template< typename ... Args >
void Logger::logTrace(Args const& ... args)
{
    std::ostringstream stream;
    using List = int[];
    (void)List{ 0, ((void)(stream << args), 0) ... };
    BOOST_LOG_SEV(log_, trace) << stream.str();
}

记录器类:

class Logger {
public:
    static Logger* getInstance(const char *logFile = "LogClient.log");
    template< typename ... Args >
    void logTrace(Args const& ... args);
private:
    Logger(std::string fileName);   
    virtual ~Logger();
    void initialize(std::string fileName);
    static Logger* logger_; // singleton instance
};

和宏:

#define LOG_TRACE(...) Logger::getInstance()->logTrace(__VA_ARGS__);

调用宏:

LOG_TRACE("A log with a number: %d", 5);

谢谢你的帮助!

编辑并求解:

这个问题与变差函数甚至宏无关,而是与链接有关。在类定义中实现logTrace可以解决问题。

代码工作:

`记录器类:

class Logger {
public:
    static Logger* getInstance(const char *logFile = "LogClient.log");
    template< typename ... Args >
    void logTrace(Args const& ... args)
    {
        std::ostringstream stream;
        using List = int[];
        (void)List{ 0, ((void)(stream << args), 0) ... };
        BOOST_LOG_SEV(log_, trace) << stream.str();
    }
private:
    Logger(std::string fileName);   
    virtual ~Logger();
    void initialize(std::string fileName);
    static Logger* logger_; // singleton instance
};

和宏:

#define LOG_TRACE(...) Logger::getInstance()->logTrace(__VA_ARGS__);

调用宏:

LOG_TRACE("A log with a number: %d", 5);

您可能在声明了Logger::logTrace()但未定义/实现的源文件(例如:在包含Logger.h的源文件中)中调用了宏(以及logTrace模板函数)。logTrace模板函数的完整定义是宏工作所必需的

我建议您在Logger类中定义logTrace成员函数:

class Logger {
public:
    static Logger* getInstance(const char *logFile = "LogClient.log");
    template< typename ... Args >
    void logTrace(Args const& ... args)
    { /* add implementation here */ }
    ...