-1

我想使用一元函数在带有 std::find 的列表中查找某个参数名称

class Parameter {
    public:
        string getName() { return mName;}
        //string mName;
    private:
        string mName;
        string mType;
        string mValue;
    };

    class Param_eq : public unary_function<Parameter, bool> {
        string mName;
    public: 
        Param_eq (const string& name) : mName(name) {}
        bool operator() (const Parameter& par) const { 
            return (mName == par.getName());
        }
    };

    double Config::getDouble(string& name) {
        list<Parameter>::iterator iParam = find(mParamList.begin(), mParamList.end(), Param_eq(name));
        double para = iParam->getDouble();
        return para;
    }
}

但我收到以下编译器错误

error C2662: 'Parameter::getName' : cannot convert 'this' pointer from 'const Parameter' to 'Parameter &'
Conversion loses qualifiers

如果我将成员变量 Parameter::mName 设为 public 并在 Param_eq::operator() 的返回语句中使用它而不是成员函数 Parameter::getName() ,则它编译不会出错。

bool operator() (const Parameter& par) const { 
    return (mName == par.mName);
}

这是为什么?成员变量和成员函数都是字符串类型。

如何使用成员函数使上述示例工作?

4

1 回答 1

2

该错误告诉您您正在对 const 引用调用非常量方法。非 const 方法可能会修改成员变量,从而违反 const 约束。

您可以通过两种方式解决此问题:

  1. 根本不调用该方法并mName直接访问变量:

    bool operator() (const Parameter& par) const { 
        return (mName == par.mName);
    }
    

    请注意,这不需要mName公开。这是有效的,因为operator()它是Parameter班级的成员。请记住,私有成员可以在类的任何方法中访问。是否访问同一类的另一个实例的私有成员并不重要。

  2. 声明getName()const对象:

    string getName() const { return mName;}
    

    注意const限定符的位置。这告诉编译器该方法不会修改任何成员变量。

于 2017-11-11T15:28:25.450 回答