下面是一个无效的Rust程序(Rust version 1.1),其中包含一个函数,该函数执行HTTP客户端请求并仅返回报头,从而删除响应中的所有其他字段。
extern crate hyper;
fn just_the_headers() -> Result<hyper::header::Headers, hyper::error::Error> {
let c = hyper::client::Client::new();
let result = c.get("http://www.example.com").send();
match result {
Err(e) => Err(e),
Ok(response) => Ok(response.headers),
}
}
fn main() {
println!("{:?}", just_the_headers());
}
以下是编译器错误:
main.rs:8:28: 8:44 error: cannot move out of type `hyper::client::response::Response`, which defines the `Drop` trait
main.rs:8 Ok(response) => Ok(response.headers),
^~~~~~~~~~~~~~~~
error: aborting due to previous error
我理解为什么借用检查器不接受这个程序--也就是说,drop
函数在移动了它的response
成员之后将使用headers
。
我的问题是:我如何才能绕过这个问题,同时仍然拥有良好的安全Rust代码?我知道我可以通过clone()
复制一份,就像这样:
Ok(response) => Ok(response.headers.clone()),
但是,从C++的角度来看,这似乎是低效的。当移动应该足够时,为什么要复制呢?我设想在C++中执行类似以下的操作来强制调用移动构造函数(如果可用):
headers_to_return = std::move(response.headers);
有没有办法放弃Rust中的副本,而是强制移动,类似于C++?
https://stackoverflow.com/questions/31307680
复制相似问题