C模板化函数可以选择成员变量吗?
作者:互联网
我希望一个类具有一个带有模板参数的函数,并且基于该模板参数,操作一个特定的成员变量.
例如,如果允许函数模板特化,那么像这样:
struct A
{
struct M1 {};
struct M2 {};
// Function template specialization not allowed :(
template<typename M>
void addM(M const &m);
template<>
void addM(M1 const &m)
{
m1_vec_.push_back(m);
}
template<>
void addM(M2 const &m)
{
m2_vec_.push_back(m);
}
std::vector<M1> m1_vec_;
std::vector<M2> m2_vec_;
};
有任何想法吗?我觉得我错过了一些简单的东西,但不能完全把手指放在上面.
解决方法:
只是超载他们:
struct A
{
struct M1 {};
struct M2 {};
void addM(M1 const &m)
{
m1_vec_.push_back(m);
}
void addM(M2 const &m)
{
m2_vec_.push_back(m);
}
std::vector<M1> m1_vec_;
std::vector<M2> m2_vec_;
};
如果你不想复制addM的代码,你可以只抽象另一个函数后面的向量选择:
struct A
{
struct M1 {};
struct M2 {};
template <class T>
void addM(T const &m)
{
getVec<T>().push_back(m);
}
std::vector<M1> m1_vec_;
std::vector<M2> m2_vec_;
private:
template<class T>
std::vector<T> &getVec();
};
template <>
std::vector<A::M1> &A::getVec() { return m1_vec_; }
template <>
std::vector<A::M2> &A::getVec() { return m2_vec_; }
标签:specialization,c,function,templates 来源: https://codeday.me/bug/20190722/1503675.html