C++11中的auto陷阱

    作者:dlite@163.com

    C++11中引入的auto关键字自动推导类型特性,可能是最方便也最容易理解的特性了。然而,即使是这个简单特性,也有陷阱,需要我们使用时注意。

    1、引用类型被推导为非引用类型

    例如:

foo(void* arg) {
  if (arg) {
    auto big = *static_cast<MyBigClass*>(arg);
    ...
  }
}
上面的代码中big会被推导为MyBigClass类型,而不是MyBigClass&类型,从而导致拷贝构造发生。解决办法是使用auto&,即:
 auto& big = *static_cast<MyBigClass*>(arg);

    2、常量迭代器的推导

    例如:

  
  map <string, string> m;
  for (auto i = m.begin(); i != m.end(); ++i) {
    cout << i->second << " is " << i->first << endl;
  }

    注意, m.begin() 返回类型是 iterator, 而不是 const_iterator, 因为这里的 m 并不是 const。C++11 中的 cbegin() 能够解决这个问题, 它返回 non-const 容器的 const 迭代器。


   另外,为明确起见,也可以给auto可加入更多限定修饰。例如:  

   const auto& s = sys.Setting();

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值