|
|
|
@ -41,9 +41,9 @@ string data on the heap." src="img/trpl04-06.svg" class="center" />
|
|
|
|
|
|
|
|
|
|
变量 `s` 有效的作用域与函数参数的作用域一样,不过当 `s` 停止使用时并不丢弃引用指向的数据,因为 `s` 并没有所有权。当函数使用引用而不是实际值作为参数,无需返回值来交还所有权,因为就不曾拥有所有权。
|
|
|
|
|
|
|
|
|
|
我们将创建一个引用的行为称为 **借用**(*borrowing*)。正如现实生活中,如果一个人拥有某样东西,你可以从他那里借来。当你使用完毕,必须还回去。我们并不拥有它。
|
|
|
|
|
我们将创建一个引用的行为称为 **借用**(*borrowing*)。正如现实生活中,如果一个人拥有某样东西,你可以从他那里借来。当你使用完后,必须还回去。因为我们并不拥有它的所有权。
|
|
|
|
|
|
|
|
|
|
如果我们尝试修改借用的变量呢?尝试示例 4-6 中的代码。剧透:这行不通!
|
|
|
|
|
那如果我们尝试修改借用的变量呢?尝试示例 4-6 中的代码。剧透:这行不通!
|
|
|
|
|
|
|
|
|
|
<span class="filename">文件名:src/main.rs</span>
|
|
|
|
|
|
|
|
|
@ -117,7 +117,7 @@ Rust 在同时使用可变与不可变引用时也采用的类似的规则。这
|
|
|
|
|
|
|
|
|
|
哇哦!我们 **也** 不能在拥有不可变引用的同时拥有可变引用。
|
|
|
|
|
|
|
|
|
|
不可变引用的用户可不希望在他们的眼皮底下值就被意外的改变了!然而,多个不可变引用是可以的,因为没有哪个只能读取数据的人有能力影响其他人读取到的数据。
|
|
|
|
|
不可变引用的借用者可不希望在借用时值会突然发生改变!然而,多个不可变引用是可以的,因为没有哪个只能读取数据的引用者能够影响其他引用者读取到的数据。
|
|
|
|
|
|
|
|
|
|
注意一个引用的作用域从声明的地方开始一直持续到最后一次使用为止。例如,因为最后一次使用不可变引用(`println!`),发生在声明可变引用之前,所以如下代码是可以编译的:
|
|
|
|
|
|
|
|
|
@ -125,7 +125,7 @@ Rust 在同时使用可变与不可变引用时也采用的类似的规则。这
|
|
|
|
|
{{#rustdoc_include ../listings/ch04-understanding-ownership/no-listing-13-reference-scope-ends/src/main.rs:here}}
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
不可变引用 `r1` 和 `r2` 的作用域在 `println!` 最后一次使用之后结束,这也是创建可变引用 `r3` 的地方。它们的作用域没有重叠,所以代码是可以编译的。编译器可以在作用域结束之前判断不再使用的引用。
|
|
|
|
|
不可变引用 `r1` 和 `r2` 的作用域在 `println!` 最后一次使用之后结束,这也是创建可变引用 `r3` 的地方。因为它们的作用域没有重叠,所以代码是可以编译的。编译器可以在作用域结束之前判断不再使用的引用。
|
|
|
|
|
|
|
|
|
|
尽管这些错误有时使人沮丧,但请牢记这是 Rust 编译器在提前指出一个潜在的 bug(在编译时而不是在运行时)并精准显示问题所在。这样你就不必去跟踪为何数据并不是你想象中的那样。
|
|
|
|
|
|
|
|
|
|