C++中的auto、auto &、const auto、const auto &

先介绍一下auto、const:

 

   在块作用域、命名作用域、循环初始化语句等等中声明变量时,关键词auto用作类型指定符,const是修饰符。

 

(1)auto

auto即 for(auto x:range)  这样会拷贝一份range元素,而不会改变range中元素;

但是使用for(auto x:vector<bool>)时得到一个proxy class,操作时会改变vector<bool>本身元素。应该使用:for(bool x:vector<bool>)

 

(2)auto&

当需要修改range中元素,用for(auto& x:range);

当vector<bool>返回临时对象,使用auto&会编译错误,临时对象不能绑在non-const l-value reference (左值引用)需使用auto&&,初始化右值时也可捕获

 

(3)const auto&

当只想读取range中元素时,使用const auto&,如:for(const auto&x:range),它不会进行拷贝,也不会修改range  

 

(4)const auto

当需要拷贝元素,但不可修改拷贝出来的值时,使用 for(const auto x:range),避免拷贝开销

 

总结:                                         

       想要拷贝元素:for(auto x:range)

       想要修改元素 : for(auto &&x:range)

       想要只读元素:for(const auto& x:range)

### C++ 中 `const auto&amp;` 遍历容器时的类型推导 当使用 `for (const auto&amp; elem : container)` 来遍历容器中的元素时,编译器会执行一系列类型的自动推导过程。对于给定的例子: ```cpp std::vector&lt;int&gt; vec = {1, 2, 3}; for (const auto&amp; elem : vec) { std::cout &lt;&lt; elem; } ``` 在这个例子中,`auto` 关键字会被替换为实际迭代变量的具体类型。 - 对于 `vec` 这样的标准库容器,其内部存储的是具体的对象而非指针。 - 使用 `const auto&amp;` 可以有效地避免不必要的拷贝操作并允许访问不可修改的对象[^1]。 具体来说,在上述代码片段里,`elem` 的确切类型将是 `const int &amp;`。这意味着每次循环迭代时,都会创建一个指向当前向量元素的常量引用,从而既提高了性能又保持了数据的安全性。 此外,如果考虑更复杂的场景,比如嵌套容器,则可以构建如下所示的类型推导树来理解整个过程中涉及的不同层次上的类型转换关系: #### 类型推导树示例 假设有一个二维整数数组表示为 `std::vector&lt;std::vector&lt;int&gt;&gt; matrix`: | 层级 | 容器/表达式 | 推导后的类型 | |------|--------------------------|-----------------------| | L0 | `matrix` | `std::vector&lt;std::vector&lt;int&gt;&gt;` | | L1 | `*it_outer` (`matrix[i]`) | `std::vector&lt;int&gt;` | | L2 | `*it_inner` (`(*it_outer)[j]`) | `int` | 因此,当我们用 `const auto&amp;` 去遍历时,每一层的实际类型分别为: - 外部循环:`const std::vector&lt;int&gt;&amp;` - 内部循环:`const int&amp;` 这表明即使面对多维结构的数据集,通过适当利用 `const auto&amp;` 范围基于的 for 循环语法,也可以实现高效而安全的操作方式。 ```cpp // 示例代码展示如何遍历二维矩阵 #include &lt;iostream&gt; #include &lt;vector&gt; int main() { std::vector&lt;std::vector&lt;int&gt;&gt; matrix{{1, 2}, {3, 4}}; // 外部循环遍历子向量 for (const auto&amp; row : matrix) { // 内部循环遍历单个元素 for (const auto&amp; elem : row) { std::cout &lt;&lt; elem &lt;&lt; &#39; &#39;; } std::cout &lt;&lt; &#39;\n&#39;; } return 0; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值