C++11中的auto陷阱

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

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

    例如:

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

    2、常量迭代器的推导

    例如:

[cpp]  view plain copy
  1. map <string, string> m;  
  2. for (auto i = m.begin(); i != m.end(); ++i) {  
  3.   cout << i->second << " is " << i->first << endl;  
  4. }  

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


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

[cpp]  view plain copy
  1. const auto& s = sys.Setting();  

posted on 2015-02-16 13:37  仗帅闯江湖  阅读(87)  评论(0编辑  收藏  举报

导航