如何复制& [u8]切片?

时间:2016-02-27 01:01:16

标签: rust borrowing

如何复制&[u8]切片的内容?

我正在尝试编写一个将缓冲区作为输入和XOR的函数 具有给定键的每个字节并返回最终结果。

我不希望它破坏输入缓冲区。

pub fn xor_buffer(buffer_in: &[u8], key: char) -> &[u8] {

    let mut buffer_out = buffer_in.clone();

    for byte in &mut buffer_out[..] {
        *byte ^= key as u8;
    }

    buffer_out
}

此代码生成以下编译时错误:

src/test.rs:29:22: 29:32 error: cannot borrow immutable borrowed content `*buffer_out` as mutable
src/test.rs:29     for byte in &mut buffer_out[..] {
                                               ^~~~~~~~~~

我知道我必须做错事。

任何帮助都会得到赞赏。

1 个答案:

答案 0 :(得分:12)

首先,您不能clone一个[T](无论T)。第3行没有克隆缓冲区,它克隆指向它的指针。如果您将绑定更改为

let mut buffer_out: &[u8] = buffer_in.clone();

你得到同样的错误。如果需要切片的独立副本,则需要将其转换为Vec或其他一些拥有的容器类型;这可以通过使用buffer_in.to_owned()(通常从借来的东西到拥有的等价物)来完成。

其次,你不能将借用返回给你在函数中创建的东西。你不能。不完全是。不,甚至不这样做。或者那个。如果返回值直接从您的某个参数借用,则可以返回借用(如&[u8])。这不是真的,因此返回类型必须Vec<u8>或其他拥有的东西。

第三,制作数组的副本然后然后改变它可能效率低下。理想情况下,您希望尽可能少地进行修改(同时避免较慢等不必要的分配)。您可以使用迭代器来完成此操作。

第四,没有保证key的值实际适合u8。您应该更改它以使key: u8向调用者明确有效的值范围。

所以,一起:

pub fn xor_buffer(buffer_in: &[u8], key: u8) -> Vec<u8> {
    // Get an iterator of `&u8`s from `buffer_in`.
    buffer_in.iter()
        // Replace each element with the xor'ed value.
        .map(|byte| *byte ^ key)
        // Collect the iterator into an owned collection.
        .collect()
}