zoukankan      html  css  js  c++  java
  • 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();  
  • 相关阅读:
    Ubuntu_14.04安装docker
    CentOS配置java运行环境
    github上传自己的开源代码
    eclipse使用maven插件创建web项目
    jar包解压后,修改完配置文件,再还原成jar包
    Python学习的几本建议书籍
    流批
    函数
    程序
    习 题
  • 原文地址:https://www.cnblogs.com/jrmy/p/14316320.html
Copyright © 2011-2022 走看看