当前位置:  开发笔记 > 编程语言 > 正文

如何正确使用enable_if?

如何解决《如何正确使用enable_if?》经验,为你挑选了1个好方法。

我需要学习如何使用enable_if.为此,我需要使用enable_if重新实现distance函数.我试过这个:

#include 
#include 
#include 
#include 
#include 

template
typename std::enable_if::value, std::iterator_traits::difference_type>::type  my_distance(In begin, In end, std::input_iterator_tag dummy){
  typename std::iterator_traits::difference_type n = 0;
  while(begin!=end){
    ++begin; ++n;
  }
  std::cout << "STEPPING" << std::endl;
  return n;
}

template
typename std::enable_if::value, std::iterator_traits::difference_type>::type my_distance(Ran begin, Ran end, std::random_access_iterator_tag dummy){
  std::cout << "RANDOM" << std::endl;
  return end - begin;
}

template  inline
typename std::iterator_traits::difference_type my_distance_wrapper(I begin, I end){
  typedef typename std::iterator_traits::iterator_category cat;
  return my_distance(begin, end, cat());
}

int main() {
  std::vector ve;
  std::list li;
  for(int i = 0; i < 3; i++){
    ve.push_back(i);
    li.push_back(i);
  }
  std::cout << my_distance_wrapper(ve.begin(), ve.end()) << std::endl;
  std::cout << my_distance_wrapper(li.begin(), li.end()) << std::endl;
  return 0;
}

我想我可以通过使用std::is_random_acces_iterator::value类似于std::is_pod::value 我检查type_traits的一些函数来做到这一点但是找不到任何东西来检查某些东西是否是特定的迭代器.我如何检查是否有random_acces_iterator?我知道我可以在一个函数中执行此操作:

template
bool f(){
  typedef typename std::iterator_traits::iterator_category cat;
  return std::random_access_iterator_tag == cat();
}

所以我的问题基本上是如何在模板中执行函数f?不能不使用enable_if是不可能的,这是我的任务的要求.我是否正确相信SFINAE会正确地丢弃其他函数,如果我可以将函数f放入该模板中?



1> Walter..:

您可以std::is_same<>按如下方式使用类型特征

template
using is_random_access_iterator = 
  std::is_same::iterator_category,
               std::random_access_iterator_tag>;

然后

template
std::enable_if_t::value,
                 typename std::iterator_traits::difference_type>
my_distance(iterator a, iterator b) { return a-b; }

template
std::enable_if_t::value,
                 typename std::iterator_traits::difference_type>
my_distance(iterator a, iterator b) { /* ... */ }

这里,std::enable_if_t<,>是一个帮助器别名(从C++ 14开始)定义为

template
using enable_if_t = typename enable_if::type;

实际上,您也可以将您的函数声明f()constexpr并直接在其中使用enable_if,即std::enable_if(), ...>.


用高性能的代码给女士们留下深刻的印象,该代码应具有较强的打字性和表现力;)
推荐阅读
LEEstarmmmmm
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有