c – 模板和重载

前端之家收集整理的这篇文章主要介绍了c – 模板和重载前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
template<class Key1,class Key2,class Type> class DualMultimapCache
  {
  public:
     std::list<std::reference_wrapper<Type>> get(Key1 const & key);
     std::list<std::reference_wrapper<Type>> get(Key2 const & key);
     template<class ...Args> Type & put(Key1 const & key,Args const & ...args);
     template<class ...Args> Type & put(Key2 const & key,Args const & ...args);
  };

在这里,我有一个类的公共接口.基础数据结构无关紧要.当Key1和Key2属于不同类型时,一切都会正常工作.如果它们最终成为相同类型,则可能无法实现过载.我这是对的吗?

如果我是,有没有办法分离重载,同时保持签名尽可能干净?

编辑:这是一个更深入的样本

template<class Key1,Args const & ...args);

  private:
     std::unordered_multimap<Key1,std::reference_wrapper<Type>> map_Key1; 
     std::unordered_multimap<Key2,std::reference_wrapper<Type>> map_Key2;
  };

  template<class Key1,class Type>
  std::list<std::reference_wrapper<Type>> DualMultimapCache<Key1,Key2,Type>::get(Key1 const & key)
  {
     auto its = map_Key1.equal_range(key);

     if (its.first == map.cend() && its.second == map.cend())
        throw std::out_of_range();
     else
        return { its.first,its.second };
  }

  template<class Key1,Type>::get(Key2 const & key)
  {
     auto its = map_Key2.equal_range(key);

     if (its.first == map.cend() && its.second == map.cend())
        throw std::out_of_range();
     else
        return { its.first,its.second };
  }

解决方法

对于相同密钥类型的情况,您可以部分专门化模板,例如
template <typename Key,typename Type>
class DualMultimapCache<Key,Key,Type>
{
public:
   std::list<std::reference_wrapper<Type>> get(Key const & key);
   template<class ...Args> Type & put(Key const & key,Args const & ...args);
};

猜你在找的C&C++相关文章