为什么 Rust 会发生可变借用错误?

3

我正在学习Rust语言,下面的代码来自在线书籍《Rust编程语言》。

fn main() {
    let mut s = String::from("hello world");

    let word = first_word(&s);

    s.clear(); // error!

    println!("the first word is: {}", word);
}


fn first_word(s: &String) -> &str {
    let bytes = s.as_bytes();

    for (i, &item) in bytes.iter().enumerate() {
        if item == b' ' {
            return &s[0..i];
        }
    }

    &s[..]
}

当我运行它时,会得到这个:
C:/Users/administrator/.cargo/bin/cargo.exe run --color=always --package rust2 --bin rust2
   Compiling rust2 v0.1.0 (C:\my_projects\rust2)
error[E0502]: cannot borrow `s` as mutable because it is also borrowed as immutable
 --> src\main.rs:6:5
  |
4 |     let word = first_word(&s);
  |                           -- immutable borrow occurs here
5 | 
6 |     s.clear(); // error!
  |     ^^^^^^^^^ mutable borrow occurs here
7 | 
8 |     println!("the first word is: {}", word);
  |                                       ---- immutable borrow later used here

error: aborting due to previous error

For more information about this error, try `rustc --explain E0502`.
error: could not compile `rust2`.

To learn more, run the command again with --verbose.

Process finished with exit code 101

但据我所知,s只是一个可变的String对象。 s.clear()只是在对象上调用一个方法,并生成一个可变借用错误? 可变借用类似于let mut a = &mut s。语句s.clear()直接使用s,那么这个借用从哪里来?


2
String::clear 的签名是 pub fn clear(&mut self)。这里是一个可变借用。 - edwardw
let word = first_word(&s); word exist only because first_word borrow s - Stargateur
@edwardw 感谢您的回复。我认为那应该是原因。 - Just a learner
@edwardw,你能把它变成一个答案,这样我就可以选择它作为正确的答案吗? - Just a learner
1个回答

5

语句s.clear()直接使用了s,借用来自哪里?

一个方法的第一个参数总是self,它代表调用该方法的结构体实例。如果不想拥有所有权,只想读取结构体中的数据而不写入,那么可以选择&self。另一方面,如果想要更改调用方法的实例,则应选择&mut self。最后,self获取所有权,并通常转换为其他内容。

在这里,{{link1:String :: clear }}被定义为:

pub fn clear(&mut self)

这是一个可变借用。如果以另一种方式调用 clear 方法,您可以清楚地看到原因:
let word = first_word(&s);
String::clear(&mut s);
println!("the first word is: {}", word);

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接