- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
为什么编译器拒绝这段代码:
struct S<'a> {
i: i32,
r: &'a i32,
}
fn main() {
let mut s = S{i: 0, r: &0};
{
let m1 = &mut s;
m1.r = &m1.i;
}
let m2 = &mut s;
}
错误是:“不能多次借用 s
作为可变的”(第一次借用:m1
,第二次借用:m2
).
为什么 m1
超出范围后,第一次借用的 s
仍然存在?
我读到有关借用范围扩展到原始借用者范围之外的信息。然而,这似乎总是涉及“接管”原始借款的原始借款人范围之外的另一个借款人,例如。此代码失败并出现完全相同的错误,这对我来说很清楚:
fn main() {
let mut s = 0;
let r: &mut i32;
{
let m1 = &mut s;
r = m1;
}
let m2 = &mut s;
}
在第一个示例中,如果我将 m1.r = &m1.i;
替换为 m1.r = &dummy;
(虚拟定义为某些 &i32)或 let dummy = &m1.i;
,代码编译。仅当我将对某个字段的引用存储在借用结构的另一个字段中时,才会发生该错误。我不明白为什么这应该将借用扩展到其范围之外。
我对代码错误的最佳猜测是:
s.r
的原始生命周期是整个main
,
当我将引用分配给 m1.r
时,它必须是原始生命周期,但是 &m1.i
仅在 期间有效>m1
活着。
但我可能错了(那时错误信息会产生误导)。
最佳答案
首先要注意的是
let mut s = S{i: 0, r: &0};
{
s.r = &s.i;
}
let m2 = &mut s;
给予
cannot borrow `s` as mutable because `s.i` is also borrowed as immutable
希望这应该是清楚的——如果一个结构自借,那么它就是被借用的。这指出了为什么任何自借用结构基本上都是无用的 - 它不能移动(使其自己的指针无效),也不能对其进行可变引用。
下一个需要理解的是,来自可变引用的不可变引用算作向可变引用的借用,因此要扩展它。例如
let mut v = ();
let r1 = &(&mut v);
let r2 = &v;
给予
cannot borrow `v` as immutable because it is also borrowed as mutable
目前尚不清楚这是否可以合法地成为对原始结构的新借用,但目前还没有这样做。
关于rust - 神秘的借用范围扩展,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32151937/
我正在使用 tcod-rs。用于绘制到 RootConsole 的每个方法都采用一个可变引用。中央循环是一个 while 循环,它等待窗口关闭、清除屏幕、绘制,然后刷新。 “检查窗口关闭”方法也采用可
This question already has answers here: How to return a reference to a sub-value of a value that is
我是新手,我已经阅读了有关所有权和借用的文档。显然,我开始为这个概念而苦苦挣扎... 这是我的代码: #[derive(Serialize, Deserialize, Debug)] pub stru
我在借阅检查器上遇到了问题。我有一个特征(Physics),它具有getters(例如velocity)和setters(例如velocity_mut)。它还具有使用getter和setter的默认方
我正在用 Rust 编写 Rogue-like。我有一个 Player,它有一个 Vec 的盒装 TimedEffects。定时效果有一个 activate(&mut Player) 和 deacti
我觉得 rc::Weak可以使用(某种)AsRef特征实现。我试图从弱指针借用一些共享内容,但这不会编译: use std::rc::Weak; struct Thing(Weak); impl Th
我正在学习Rust。对于我的第一个程序,我编写了以下代码来维护有关部分排序的数据: use std::collections::{HashMap, HashSet}; struct Node {
这个问题在这里已经有了答案: Cannot borrow as immutable because it is also borrowed as mutable in function argume
在尝试实现一个迭代器以产生对链表元素的可变引用时,我偶然发现了一个奇怪的问题。 这很好用: impl Iterator for LinkedListIterator{ fn next(&mut
我有this minimal example code : use std::borrow::BorrowMut; trait Foo {} struct Bar; impl Foo for Bar
struct State { x: i32 } trait A { fn a(&mut self, b: &i32); } impl A for State { fn a(&m
我有一个 Element 结构,它实现了一个更新方法,该方法需要一个滴答持续时间。该结构包含一个组件向量。允许这些组件在更新时修改元素。我在这里遇到借用错误,我不确定该怎么做。我尝试用 block 修
我正在尝试做这样的事情 use std::cell::{RefCell,Ref,RefMut}; use std::rc::Rc; struct Entity; struct Tile { e
我已连接到 Deribit websocket 以获取选项数据,但以下代码片段仅获得一个有效的数据响应,然后停止更新,但表示它仍在运行。 该网站建议使用 asyncio 模块,但能够使用以下代码片段提
我是一名优秀的程序员,十分优秀!