我有以下工作代码:
class person
{
private:
int age_;
public:
person() : age_(56) {}
void age(int a) { age_ = i; }
}
template < class T, void (T::* ...FUNC)(int) > class holder;
template < class T, void (T::*FUNC)(int)>
class holder<T, FUNC>
{
public:
typedef typename T::value_type value_type;
public:
explicit holder() : setter(FUNC) { std::cout << "func\n"; }
private:
std::function<void (value_type&, int)> setter;
};
template < class T>
class holder<T>
{
public:
explicit holder() { std::cout << "plain\n"; }
};
int main()
{
holder<person> h1;
holder<person, &person::age> h2;
// this does not work:
holder<int> h3;
}
我知道在int(或任何其他非类,结构或联合类型)的情况下,由于第二个模板参数中的expect成员函数,代码不起作用。
我的问题是如何更改代码以使其正常工作。我需要它以这种方式工作,使我的持有人类的使用变得简单。
我已尝试使用类型特征,并将成员函数指针移动到类的构造函数。没有成功。
有什么建议吗?提前谢谢!
答案 0 :(得分:3)
更新:我让它与std::conditional
合作:
template < class T, void (std::conditional<std::is_class<T>::value, T, struct dummy>::type::* ...FUNC)(int) > class holder;
另一种可能的解决方案是使用子类:
template < class T, void (T::*FUNC)(int) >
class class_holder
{
public:
typedef typename T::value_type value_type;
public:
explicit class_holder() : setter(FUNC) { std::cout << "func\n"; }
protected:
std::function<void (value_type&, int)> setter;
}
template <class T, bool IsClass = std::is_class<T>::value>
class holder;
template <class T>
class holder<T, true> : public class_holder<T>
{
public:
template <void (T::*FUNC)(int) >
class with_member : public class_holder<T, FUNC>
{
};
};
template <class T>
class holder<T, false>
{
public:
explicit holder() { std::cout << "plain\n"; }
};
int main()
{
holder<person> h1;
holder<person>::with_member<&person::age> h2;
holder<int> h3;
}
我没有编译这个,所以告诉我是否有些东西不起作用。