我很难看到这是如何转移所有权的。这是我的代码:
let res = screenshot::take_screenshot(0);
let file = File::open("test.png").expect("Failed to open file");
let encoder = PNGEncoder::new(file);
encoder.encode(&res.into_raw(),
res.width(),
res.height(),
ColorType::RGBA(0)
);
screenshot::take_screenshot
是一个返回ImageBuffer<Rgba<u8>, Vec<u8>>
的函数。这是我得到的编译器错误:
error[E0382]: use of moved value: `res`
--> src/main.rs:21:37
|
21 | encoder.encode(&res.into_raw(), res.width(), res.height(), ColorType::RGBA(0));
| --- ^^^ value used here after move
| |
| value moved here
|
= note: move occurs because `res` has type `image::ImageBuffer<image::Rgba<u8>, std::vec::Vec<u8>>`, which does not implement the `Copy` trait
error[E0382]: use of moved value: `res`
--> src/main.rs:21:50
|
21 | encoder.encode(&res.into_raw(), res.width(), res.height(), ColorType::RGBA(0));
| --- value moved here ^^^ value used here after move
|
= note: move occurs because `res` has type `image::ImageBuffer<image::Rgba<u8>, std::vec::Vec<u8>>`, which does not implement the `Copy` trait
我正在尝试传递一个切片,我相信它是矢量的参考,不是吗?这意味着不会传递所有权,并且不会移动矢量。我知道我做错了什么,这可能很简单。
答案 0 :(得分:5)
这只是一个运算符优先级问题:方法在引用运算符&
之前应用:
&(res.into_raw()) // This
(&res).into_raw() // Not this
调用into_raw
取得所有权,价值消失。
你可以这样做:
let w = res.width();
let h = res.height();
let r = res.into_raw();
encoder.encode(&r, w, h, ColorType::RGBA(0));
可能有更好的东西,但你没有提供MCVE所以很难迭代解决方案。从文档中盲目地猜测,它看起来应该有效:
extern crate image;
use image::{png::PNGEncoder, ColorType, ImageBuffer, Rgba};
use std::io;
fn repro<W: io::Write>(res: ImageBuffer<Rgba<u8>, Vec<u8>>, file: W) -> Result<(), io::Error> {
let encoder = PNGEncoder::new(file);
encoder.encode(&res, res.width(), res.height(), ColorType::RGBA(0))
}
fn main() {}