- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想获取一个链表并用结构的实例填充它,但前提是该列表尚未包含我正在考虑添加的项目。
我正在处理点,因此如果 (3,5) 在列表中我不想添加它,否则我会添加。
我当前的代码:
use std::collections::LinkedList;
struct Location {
x: i32,
y: i32,
}
fn main() {
let mut locations = LinkedList::new();
loop {
let location_set = &mut locations;
// Scanner stuff happens.
if !has_location(location_set, &next_checkpoint_x, &next_checkpoint_y) {
let point = Location {
x: next_checkpoint_x,
y: next_checkpoint_y,
};
locations.push_back(point);
}
}
}
fn has_location(location_list: LinkedList<Location>, target_x: &i32, target_y: &i32) -> bool {
true // Just until I can figure out this mutability stuff
}
我已经能够通过这些更改让它运行,但这对我来说似乎是错误的。
loop {
if !has_location(&mut locations, &next_checkpoint_x, &next_checkpoint_y) {
// stuff
}
}
fn has_location(location_list: &LinkedList<Location>, target_x: &i32, target_y: &i32) -> bool {
true
}
我不希望 has_location
能够改变链表,我只希望它能够借用它以便它可以查看它的内部。我不想考虑影响它检查的链表的 has_location
(或类似函数)。这就是我创建 location_set
的原因。我想要一些东西以只读方式引用位置,并将其传递给 has_location
函数,并且要在调用 has_location 后不销毁所引用的内容(位置)
功能。我在函数调用的参数传递中包含 &
,因为我不想传递的参数被销毁 - 所以我想借用它们?
我想要的东西是否有意义 - 如果我最初将位置声明为可变链表,我可以将它的不可变版本传递给函数进行评估吗?
最佳答案
如果您有一个可变借用,您总是可以重新借用它作为一个不可变借用。这甚至会隐式发生( &mut T
将强制转换为 &T
)。因此,您可以只传递 location_set
至 has_location
直接地。或者如果你想明确表示函数不会改变它的参数,你可以写成 &*location_set
而不是 location_set
(虽然我觉得这是不必要的)。
另外请注意,当不可变借用存在时,您不能使用可变借用;不可变借用在范围内卡住数据结构。同样,当变量在范围内有可变借用时,您不能使用该变量。在您的第一个代码示例中,您不能引用 locations
同时location_set
在范围内,因为 location_set
在 locations
上进行可变借用, 但你可以只使用 location_set
再次,因为 push_back
只需要一个可变借用(它不需要 LinkedList
按值)。
仅检查数据结构的函数通常会收到对数据结构的不可变借用。如果数据结构改为按值传递,函数将取得它的所有权并因此在返回之前销毁它(除非它被移动到别处)。因此,是的,你想要 has_location
接受对 LinkedList
的不可变借用.通过接受不可变借用(而不是可变借用),编译器将阻止您修改 LinkedList
。 (除非您使用不安全的代码)。
综合起来:
use std::collections::LinkedList;
struct Location {
x: i32,
y: i32,
}
fn main() {
let mut locations = LinkedList::new();
let next_checkpoint_x = 0;
let next_checkpoint_y = 0;
loop {
let location_set = &mut locations;
// Scanner stuff happens.
if !has_location(location_set, &next_checkpoint_x, &next_checkpoint_y) {
let point = Location { x: next_checkpoint_x, y: next_checkpoint_y };
location_set.push_back(point);
}
}
}
fn has_location(location_list: &LinkedList<Location>, target_x: &i32, target_y: &i32) -> bool {
true
}
Something I don't understand though is in your example,
location_set
is passed tohas_location
directly (so the function owns it, right?). This in my mind means that at the end ofhas_location
's scope,location_set
should be destroyed, no? How doeslocation_set
continue to exist to be used in theif
block?
不,has_location
不拥有location_set
.如果这是未实现 Copy
的任何其他类型(例如 String
),那么你是对的,但引用有特殊规则,使它们更方便使用。
当您将一个引用传递给一个函数时,编译器会自动重新借用该引用以生成一个新的引用,通常具有较短的生命周期。在这里,编译器正在重新借用可变引用并生成不可变引用;在不可变引用超出范围之前,不能使用可变引用(这里不可变引用未绑定(bind)到变量,因此您不会真正注意到这一点)。从概念上讲,就好像您将不可变引用传递给可变引用(在 Rust 中, & &mut T
不允许您改变 T
,因为该外部引用可能有多个副本),只是两个引用被“扁平化”。
Also if
location_set
is immutable, how ispush_back
able to add to the end of the list, is it because the function coerces the mutable borrow into an immutable borrow?
location_set
仍然是可变引用(因为我们使用 &mut
运算符创建它)。事实has_location
对不可变引用进行操作不会改变 location_set
的事实是可变引用。一旦调用has_location
已评估,location_set
可以作为可变引用重用,因此 push_back
等变异操作是允许的。
请记住,可变性是 Rust 纯粹的编译时概念; mut
或缺少 mut
只是让编译器验证您的代码没有执行非法操作,但是一旦您的代码被编译,这些标记就无处可见。
关于rust - 借用检查器检查可变引用的最佳实践是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42605042/
本文分享自华为云社区《大模型LLM之分布式训练》,作者: 码上开花_Lancer。 随着语言模型参数量和所需训练数据量的急速增长,单个机器上有限的资源已无法满足大语言模型训练的要求。需要设计分布式训
本文分享自华为云社区《五大基础算法--动态规划法》,作者: 大金(内蒙的)。 一、基本概念 动态规划法,和分治法极其相似。区别就是,在求解子问题时,会保存该子问题的解,后面的子问题求解时,可以直接拿来
pip install scp pip install pexpect 测试代码: import os import stat import paramiko # 用于调用scp命令 def s
我目前正在实现“ token ”REST 服务。 token 只是一个字符串,由一些参数构建而成,然后经过哈希处理并在一定时间后过期。 我想在我的 REST 服务中有一个可以验证 token 的端点,
打开软删除后,我在客户端上添加一条记录,推送,删除添加的记录推送,然后尝试使用与初始记录相同的主键添加新记录(然后推送),我得到一个异常(exception)。 EntityDomainManager
打开软删除后,我在客户端上添加一条记录,推送,删除添加的记录推送,然后尝试使用与初始记录相同的主键添加新记录(然后推送),我得到一个异常(exception)。 EntityDomainManager
我有一个应用程序,每 x 秒接收一次天气信息。我想将此数据保存到 XML 文件中。 我应该为每个天气通知创建一个新的 XML 文件,还是将每个通知附加到同一个 XML 文件中?我不确定 XML 标准的
我猜我们大多数人都必须在某个时候处理这个问题,所以我想我会问这个问题。 当您的 BLL 中有很多集合并且您发现自己一遍又一遍地编写相同的旧内联(匿名)谓词时,显然有必要进行封装,但实现封装的最佳方
我有一些 c# 代码已经运行了一段时间了..我不得不说,虽然我了解 OO 原则的基础知识,但显然有不止一种方法可以给猫剥皮(尽管我讨厌那个短语!)。 因此,我有一个基本抽象类作为基本数据服务类,如下所
我设计了一个 SQL 数据库系统(使用 Postgre),我有一个问题,即创建一个关系/引用的常见做法是什么,这种关系/引用即使在引用的对象被删除时也能持续存在。 比如有一个UserORM,还有Act
我们的目标是搜索用户输入的字符串并计算在其中找到多少元音。不幸的是我被困在这里,有什么帮助吗? def numVowels(s): vowels= "AEIOUaeiou" if s
我有一个适用于我的“items”int 数组的旋转函数。下面的代码完成了它,除了我不必要地传输值。我正在努力实现“就地”轮换。我的意思是 ptrs 会递增或递减,而不是从数组中获取值。我需要通过这种方
我有一个 json 存储在我的应用程序文档文件夹中,我需要在我的所有 View 中使用它。我正在加载 json 并将其添加到每个 View 中的 NSMutableArray。但现在我了解到,我可以将
我用 C++ 开始了一个项目。这种语言的内存管理对我来说是新的。 我过去常常使用 new () 创建对象,然后传递指针,虽然它可以工作,但调试起来很痛苦,人们看到代码时会用有趣的眼神看着我。我为它没有
已结束。 这个问题是 off-topic .它目前不接受答案。 想要改进这个问题? Update the question所以它是on-topic堆栈溢出。 关闭 10 年前。 Improve thi
保持类松散耦合是编写易于理解、修改和调试的代码的一个重要方面——我明白这一点。然而,作为一个新手,几乎任何时候我都会超越我所苦苦挣扎的最简单的例子。 我或多或少地了解如何将字符串、整数和简单数据类型封
我发现我需要编写大量重复代码,因为我无法从其他 Controller 调用函数。例如,这里新闻提要内容在我的代码中重复,我对一个 Controller 做一些特定的事情,然后需要像这样加载我的新闻提要
假设需要一种数字数据类型,其允许值在指定范围内。更具体地说,假设要定义一个整数类型,其最小值为0,最大值为5000。这种情况在很多情况下都会出现,例如在对数据库数据类型,XSD数据类型进行建模时。 在
假设我想循环整个数组来访问每个元素。使用 for 循环、for...in 循环或 for...of 循环是 JavaScript 开发人员的标准做法吗? 例如: var myArray = ["app
我有一个旧的 SL4/ria 应用程序,我希望用 Breeze 取代它。我有一个关于内存使用和缓存的问题。我的应用程序加载工作列表(一个典型的用户可以访问大约 1,000 个这些工作)。此外,还有很多
我是一名优秀的程序员,十分优秀!