链接使用log4cplus的个人库时出错

时间:2013-06-02 17:49:53

标签: c++ g++ static-linking log4cplus

我试图链接一个使用lib4cplus的个人库的简单代码时遇到了一个奇怪的问题。

包含主代码的文件非常简单,不使用log4cplus。我只使用lib4cplus进入库。该库正确编译但是当我将主文件与库链接时,它会发生类似错误(logger var未在架构x86_64下定义)

g++ leer.cpp -c
ar r libfichero.a blowfish.o clase.o
g++ -o Class  leer.o -lm -lz -llog4cplus libfichero.a
Undefined symbols for architecture x86_64:
  "fichero::loggerFichero", referenced from:
      fichero::startLoggers()      in libfichero.a(clase.o)
      fichero::fichero()in libfichero.a(clase.o)
      fichero::fichero()in libfichero.a(clase.o)
  "fichero::errorLoggerFichero", referenced from:
      fichero::startLoggers()      in libfichero.a(clase.o)
      fichero::fichero()in libfichero.a(clase.o)
      fichero::fichero()in libfichero.a(clase.o)
ld: symbol(s) not found for architecture x86_64
collect2: ld returned 1 exit status
make[1]: *** [all] Error 1
make: *** [p21] Error 2

当我想要定义我的私有记录器变量(ficheroLogger和errorFicheroLogger)时会出现错误。

这是我库中cpp文件中的代码。

bool fichero::startLoggers()
{
    // Aquí inico los loggers que voy a usar en la clase.
    loggerFichero = Logger::getInstance(LOG4CPLUS_TEXT("utils"));
    errorLoggerFichero = Logger::getInstance("BigFail");
}


// Método para definir los logs.
bool fichero::initLogFichero()
{
    cout << "Entering LOG Config part..." << endl;
    LogLog::getLogLog()->setInternalDebugging(true);
    Logger root = Logger::getRoot();

    // Load the properties
    PropertyConfigurator::doConfigure("ficheroLog4cplus.properties");

    Logger fileLog = Logger::getInstance(LOG4CPLUS_TEXT("filelogger"));

    // Log with INFO level
    LOG4CPLUS_INFO(fileLog, "Application startup");

    cout << "Exiting the main part()..." << endl;

    // Log with INFO level
    if (fileLog.isEnabledFor(INFO_LOG_LEVEL))
    {
        LOG4CPLUS_WARN(fileLog, "Application shutdown");
    }

    startLoggers();

    return true;
}

// Constructor y Destructor
fichero::fichero()
{
    nomFile = "file.txt";

    delimitador = "";
    hayDelimiatador = false;

    initLogFichero();

    LOG4CPLUS_WARN(loggerFichero, "Inicio normal");
    LOG4CPLUS_WARN(errorLoggerFichero, "Inicio error.");
}

1 个答案:

答案 0 :(得分:0)

这看起来不像log4cplus的问题。尝试重新调整命令行:

g++ -o Class leer.o libfichero.a -llog4cplus -lz -lm