c++ - 在 A 或 B 的任何容器上重载模板成员函数

标签 c++ templates containers template-specialization

我有 2 个现有的类 A 和 B。我想实现第三个结构 C,这样 C 实现 operator() ,它将接受 A 的任何容器或使用不同的实现 B 的任何容器. 是否可以使用模板特化来做这样的事情?

最佳答案

enable_if 在很多情况下都非常有用,但在这种情况下我通常更倾向于使用标签调度。在我看来,代码看起来更清晰,行为更可预测,如果您尝试错误地使用它,错误消息会稍微更有意义。

struct C
{
    template <class T>
    void operator()(const T& container) const
    {
        operator()(container, Tag<typename T::value_type>());
    }

private:
    template <class V> struct Tag {};

    template <class T>
    void operator()(const T& container, Tag<A>) const
    {
        std::cout << "A\n";
    }

    template <class T>
    void operator()(const T& container, Tag<B>) const
    {
        std::cout << "B\n";
    }
};

int main()
{
    std::vector<A> a;
    std::list<B> b;
    C c;
    c(a);
    c(b);
}

关于c++ - 在 A 或 B 的任何容器上重载模板成员函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23152165/

相关文章:

ruby - 仅当在模板中定义变量时 Puppet 3 循环执行

python - 如何从 Dockerized Python Web 应用程序提供静态文件?

c++ - 无法获取随机字符串

WordPress:对不同的自定义帖子类型使用自定义类别模板(category.php)

c++ - Qt5 与 CMake : how to find qt translations dir?

android - 如何使用现有的 android 项目作为其他 android 项目的库/源?

c++ - "this"指针和容器

matlab - 定义具有多个无法组织成矩阵的输出的函数

c++ - 无法在spdlog中格式化参数

c++ - 位图 24 到 32 和后面