指向模板类中成员函数的指针

时间:2012-07-05 13:13:55

标签: c++ templates function-pointers

我希望使用指向成员函数的指针来消除决策所消耗的过程。我需要为用户选项打开或关闭在有限连续域上定义的函数的域检查。

不使用模板时,可以指向成员函数。但在这里我必须概括我的实现。

具体来说,我班上有三个成员函数:

1. value是一个成员函数返回由function指向的成员计算的值。 function是一个指向checkedValueuncheckedValue的函数指针。 2。checkedValue是一个成员函数,如果输入在指定范围内,则计算并返回结果。 else抛出std :: domain错误。 3。uncheckedValue计算并返回结果,无论域名如何。

template <typename T>
class IO
{
private:
    typedef T (IO<T>::*functionPtr)(const std::string& name, const T& input) const;
    functionPtr function;
    bool domainValidation;
    void setDomainValidation(const bool& value);
    //...
public:
    // ...
    T value(const std::string& name, const T& input) const;
    T uncheckedValue(const std::string& name, const T& input) const;
    T checkedValue(const size_t& index, const T &input) const;
};

// Implementation:

template <typename T>
void IO<T>::setDomainValidation(const bool &value)
{
    domainValidation = value;
    if(domainValidation)
    {
        // function points to checkedValue()
        function =  & IO<T>::checkedValue; // Here I got undefinded reference error
    }
    else
    {
        // function points to uncheckedValue()
    }
}

template <typename T>
T IO<T>::value(const string &name, const T &input) const
{
    return (this->*function)(name,input);
}

template <typename T>
T IO<T>::uncheckedValue(const string &name, const T &input) const
{
    // simply calculate and return the result
}

template <typename T>
T IO<T>::checkedValue(const string &name, const T &input) const
{
    // if input is in domain, calculate and return the result
    // else throw a std::domain error
}

2 个答案:

答案 0 :(得分:4)

这看起来像是一个错字:函数指针的函数签名是

...(const std::string &, const T &) ...

checkedValue的签名是

...(const size_t &, const & T) ...

如果更改签名以匹配函数指针,则代码示例将为我编译。关于性能:你是否确定(如已经分析或查看程序集)value-method中的简单if子句比通过函数指针的(可能的)间接更差?显然,无法内联对checked或uncheckedValue的调用。

答案 1 :(得分:3)

您的功能有签名

T checkedValue(const size_t& index, const T &input) const;

但不是

T IO<T>::checkedValue(const string &name, const T &input) const;

注意第一个参数的类型之间的区别。