C++11中的auto陷阱

    作者:[email protected]

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

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

    例如:

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

    2、常量迭代器的推导

    例如:

  
  map  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();

你可能感兴趣的:(C/C++编程,c++,iterator,string,c)