其他分享
首页 > 其他分享> > C模板化函数可以选择成员变量吗?

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