如何复制&[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[..] {
^~~~~~~~~~
我知道我必须做错事。
任何帮助都会得到赞赏。
答案 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()
}