boost::iterator_adaptor (II) (转)

boost::iterator_adaptor (II) (转)[@more@]

发信人: huxw (米老鸭和唐老鼠), 信区: Programming
标  题: boost::iterator_adaptor  (II)
发信站: BBS 水木清华站 (Sun May 19 22:27:09 2002)

申明:这里只是一种技巧。从某种眼光看来过于花哨。所以我只是介绍
介绍,并不是要鼓励大家都这样去折磨你的编译器。 ;)

  II) 简化复杂的模板参数列表

  iterator模版中用到很多模版参数, value, pointer, reference等等,
  他们之间并非没有联系. 事实上, 这些模版参数的缺省值本来都是推算
  出来的.

  template   class Value = typename std::iterator_traits::value_type,
  class Reference = typename iterator_defaults::reference,
  class Pointer = typename iterator_defaults::pointer,
  class Category = typename std::iterator_traits::iterator_category,
  class Distance = typename std::iterator_traits::difference_type
  >

  很合理是吧, 但是有没有想过如果我们并不需要提供那么多模版参数的
  时候总需要输入那么多, 会怎么样? 有没有想过如果这样的推算推不出
  结果来怎么办? 所以最后我们看到的代码是酱紫的.

  template   class Value = ::boost::detail::default_argument,
  class Reference = ::boost::detail::default_argument,
  class Pointer = ::boost::detail::default_argument,
  class Category = ::boost::detail::default_argument,
  class Distance = ::boost::detail::default_argument
  > struct iterator_adaptor

  这样的代码能带来什么好处呢? 就是我们可以酱紫实例化模版了.

  iterator_adaptor  transform_iterator_policies,
  iterator_category_is<:input_iterator_tag>,
  value_type_is, reference_is
  > myite;

  注意到了嘛, 模版参数根本不和我们声明的时候相同. ;) 多奇妙啊,
  我们用函数缺省参数的时候都不能这样.

  声明: int foo(int i, long j = 0, double k = 9.8);
  而调用的时候:foo(1, k = 8.7);  // 错误

  但是模版实例化的时候可以. 原因就在于iterator_adaptor开始时做的
  手脚. 他用了一个iterator_traits_gen的模板. 这个模版并不在乎我
  们给的模版参数的意义, 他只是简单的构建一个typelist, 然后利用
  find_param从typelist中把需要的类型捡出来.

  typedef detail::cons_type< typename make_arg::type,
  detail::cons_type::type,
  detail::cons_type::type,
  detail::cons_type::type,
  detail::cons_type::type,
  end_of_list> > > > > ArgList;

  typedef typename find_param::type Val;
  typedef typename find_param::type Diff;
  typedef typename find_param::type Cat;
  typedef typename find_param::type Ptr;
  typedef typename find_param::type Ref;

  结合上面的代码中出现的value_type_is类似的方法, 你一定直觉到make_arg
  有问题. 确实,

  template struct is_named_parameter {
  enum { value = false; }
  };

  template struct is_named_parameter > { enum { value = true }; };

  template
  struct make_arg {
  enum { is_named = is_named_parameter::value };
  //我们使is_named_parameter对value_type_is类型做特化, 那么.... 呵呵
  typedef typename if_true::template
  then  make_key_value>::type Make;  //反之就是make_key_valye::type
  typedef typename Make::template select::type type;
  };

  struct make_named_arg {
  template
  struct select { typedef typename Value::type type; };
  };  //如果用value_type_is做模版参数
  struct make_key_value {

  struct make_named_arg {
  template
  struct select { typedef typename Value::type type; };
  };  //如果用value_type_is做模版参数
  struct make_key_value {
  template
  struct select { typedef detail::cons_type type; };
  };  //如果用T做模版参数

  是不是有了一点心得了? 那么长的篇幅, 看到这里真不容易. 既然都看
  到这里了, 就帮个忙, 给peach写一封信骚扰, 请他写写
  boost::function吧. ;)

 

-- 
ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz 


※ 修改:·huxw 於 May 19 22:28:23 修改本文·[FROM:  166.111.172.6] 
※ 来源:·BBS 水木清华站 bbs.edu.cn·[FROM: 166.111.172.6]


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/10752043/viewspace-992677/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/10752043/viewspace-992677/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值