From 01342b9c16c6011040b1845f7a6e2caed81c44e1 Mon Sep 17 00:00:00 2001 From: shinolr Date: Fri, 3 Jun 2022 20:58:33 +0800 Subject: [PATCH 1/2] fix: wrong type name --- src/ch15-05-interior-mutability.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/ch15-05-interior-mutability.md b/src/ch15-05-interior-mutability.md index 517cd29..fefe3fd 100644 --- a/src/ch15-05-interior-mutability.md +++ b/src/ch15-05-interior-mutability.md @@ -112,7 +112,7 @@ ### `RefCell` 在运行时记录借用 -当创建不可变和可变引用时,我们分别使用 `&` 和 `&mut` 语法。对于 `RefCell` 来说,则是 `borrow` 和 `borrow_mut` 方法,这属于 `RefCell` 安全 API 的一部分。`borrow` 方法返回 `Ref` 类型的智能指针,`borrow_mut` 方法返回 `RefMut` 类型的智能指针。这两个类型都实现了 `Deref`,所以可以当作常规引用对待。 +当创建不可变和可变引用时,我们分别使用 `&` 和 `&mut` 语法。对于 `RefCell` 来说,则是 `borrow` 和 `borrow_mut` 方法,这属于 `RefCell` 安全 API 的一部分。`borrow` 方法返回 `Ref` 类型的智能指针,`borrow_mut` 方法返回 `RefMut` 类型的智能指针。这两个类型都实现了 `Deref`,所以可以当作常规引用对待。 `RefCell` 记录当前有多少个活动的 `Ref` 和 `RefMut` 智能指针。每次调用 `borrow`,`RefCell` 将活动的不可变借用计数加一。当 `Ref` 值离开作用域时,不可变借用计数减一。就像编译时借用规则一样,`RefCell` 在任何时候只允许有多个不可变借用或一个可变借用。 From 97b1fb9671aa3ae6bc42fbc2de89b955bb40fb2a Mon Sep 17 00:00:00 2001 From: shinolr Date: Fri, 3 Jun 2022 21:42:31 +0800 Subject: [PATCH 2/2] update ch15-06-reference-cycles.md --- src/ch15-06-reference-cycles.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/ch15-06-reference-cycles.md b/src/ch15-06-reference-cycles.md index ba49e3b..c05037a 100644 --- a/src/ch15-06-reference-cycles.md +++ b/src/ch15-06-reference-cycles.md @@ -61,7 +61,7 @@ Rust 的内存安全性保证使其难以意外地制造永远也不会被清理 因为 `Weak` 引用的值可能已经被丢弃了,为了使用 `Weak` 所指向的值,我们必须确保其值仍然有效。为此可以调用 `Weak` 实例的 `upgrade` 方法,这会返回 `Option>`。如果 `Rc` 值还未被丢弃,则结果是 `Some`;如果 `Rc` 已被丢弃,则结果是 `None`。因为 `upgrade` 返回一个 `Option>`,Rust 会确保处理 `Some` 和 `None` 的情况,所以它不会返回非法指针。 -我们会创建一个某项知道其子项**和**父项的树形结构的例子,而不是只知道其下一项的列表。 +我们会创建一个某项知道其子项和父项的树形结构的例子,而不是只知道其下一项的列表。 #### 创建树形数据结构:带有子节点的 `Node`