boost学习之-enable_if

本文深入探讨了Boost库中的disable_if特性,解释了如何利用此工具根据条件排除模板函数或特化版本参与重载决议的过程。通过具体代码示例,详细说明了disable_if的工作原理及其在模板元编程中的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

用法:

1

  • 你需要在把一个符合某些条件的函数加入到或排除出重载决议集合中。

  • 你需要根据某个条件将一个类模板的特化版本加入到或排除出特化集合中。

2   实现方法,看如下例子:

void some_func(int i)

{

      std::cout << "void some_func(" << i << ")\n";
}

template <typename T> void some_func(
T t,typename boost::disable_if<
boost::is_integral<T> >::type* p=0)

{


      typename T::type variable_of_nested_type;
      std::cout << "template <typename T> void some_func(T t)\n";


}


int mian

{

    short s=12;
    some_func(s);

return 0

}

如果第二个函数没有,typename boost::disable_if<boost::is_integral<T> >::type* p=0参数,编译该程序会报错,错误原因是main中采用了

模版形式的some_func函数,为了排除该模板函数,而采用第一个int参数的some_func,需要用到disable_if;

disable_if在boost实现中相关代码如下:

  template <bool B, class T = void>
  struct disable_if_c {
    typedef T type;
  };

  template <class T>
  struct disable_if_c<true, T> {};

  template <class Cond, class T = void>
  struct disable_if : public disable_if_c<Cond::value, T> {};


如果T是int类型或short类型,编译器会推演实现如下形式的类,也是disable_if的基类,

  template <class T>
  struct disable_if_c<true, T> {};

该类没有定义typedef type,所以不会实例化模板形式的some_func,所以

模板形式的some_func也不会成为模板推演中的候选函数,所以就被排除在外了;

这个就是:disable_if的内部原理,通过阻止函数的实例化,达到成为模板推演候选函数的目的;


综上,disable_if的原理有点难以理解,但是还是有很大作用的,在实际中,我感觉只要不是要实现boost库之类的库,一般都不会用到这个东西;





评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值