0

提前对格式表示抱歉。想不通...

我通过参数将配置文件传递给程序

我正在尝试从特定参数中读取值

我有一个 cofigReader 类,它具有以下方法,用于从给定特定参数的配置文件中返回字符串

我的问题,

它永远找不到参数。found 是 0 或 -1....

string configReader::value(string config_file, string parameter)
{
    string value;
    char config_delimiter = '=';
    size_t found;
    file.open(config_file);
    std::string line;
    bool param_found = false;
    while(param_found == false){
        while (!file.eof())
        {       
            getline(file,line);
            logger.writetolog("INFO","Looking for " + parameter +
                         " on line "+ line); 
            found = line.find(parameter);
            logger.writetolog("INFO",int(found));
            if(found!=string::npos){
                param_found = true;
            }
        }
        param_found = true;
    }
    if (found!=string::npos)
    {   
        size_t a = line.find(config_delimiter)+1;
        logger.writetolog("INFO","Found" + parameter + 
                   "splitting string at delimter" + config_delimiter + 
                   " and return right side value");     
        value = line.substr(a);
        return value;
    }
    else
    {
        return value;
    }
    file.close();
}

更多信息。配置文件长这样。

toemail=someemailaddress@gmail.com
outputdir=C:\tmp

像这样使用的 configReader 类

//attempt to parse out the required parameters for the program
string toemail = config.value(configFileArg,"toemail"); 

它总是返回空

4

2 回答 2

3

while (!file.eof())找到匹配项后循环继续,覆盖found稍后检查的值。

您可以通过将循环更改为类似的方式来解决此问题

bool param_found = false;
while (!param_found && !file.eof()) {       
    if (getline(file,line)) {
        break;
    }
    logger.writetolog("INFO","Looking for " + parameter +" on line "+ line); 
    found = line.find(parameter);
    logger.writetolog("INFO",int(found));
    if(found!=string::npos){
        param_found = true;
        break;
    }
}

反而。(请注意,此代码删除了您的 while(param_found == false) 循环。正如 sftrabbit 指出的那样,该循环是不必要的。)

于 2012-12-19T17:40:02.060 回答
2

编写循环的惯用方法是:

bool param_found = false;

while (std::getline(file,line)) //<-- this is idiomatic loop!
{                               //successfully read OR exit from the loop

    logger.writetolog("INFO","Looking for " + parameter +" on line "+ line); 
    found = line.find(parameter);
    logger.writetolog("INFO",int(found));
    if(found!=string::npos){
        param_found = true;
        break;
    }
}

eof()编写循环时不应使用:

这两个主题详细讨论了这一点。

于 2012-12-19T17:46:13.380 回答