gpt4 book ai didi

rust - 嵌套闭包借用失败

转载 作者:行者123 更新时间:2023-11-29 08:32:23 25 4
gpt4 key购买 nike

我想解析 YAML 文件并将服务中的值用于 HTTP 请求。第 35 行是 main 函数的结束。

extern crate hyper;
extern crate libc;
extern crate yaml_rust;

use hyper::rt::Future;
use hyper::service::service_fn_ok;
use hyper::{Body, Response, Server};
use std::sync::Arc;
use yaml_rust::YamlLoader;

fn main() {
let content: String = String::from("response: Hello world");
let cfg = Arc::new(YamlLoader::load_from_str(content.as_str()).unwrap());
let cfg0 = (&cfg[0]).clone();
let cfg_response = (&cfg0)["response"].as_str().unwrap();

// A `Service` is needed for every connection, so this
// creates on of our `hello_world` function.
let handle = move || {
let cfg_response = cfg_response.clone();

service_fn_ok(move |_| Response::new(Body::from(String::from(cfg_response.clone()))))
};

// Serve HTTP protocol
// This is our socket address...
let addr: std::net::SocketAddr = ([127, 0, 0, 1], 3000).into();

let server = Server::bind(&addr)
.serve(handle)
.map_err(|e| eprintln!("server error: {}", e));

// Run this server for... forever!
hyper::rt::run(server);
}

不幸的是,我遇到了导致奇怪的借用错误的嵌套闭包:

error[E0597]: `cfg0` does not live long enough
--> src/main.rs:15:26
|
15 | let cfg_response = (&cfg0)["response"].as_str().unwrap();
| ^^^^ borrowed value does not live long enough
...
35 | }
| - borrowed value only lives until here
|
= note: borrowed value must be valid for the static lifetime...

我试过了

  1. 在借用之前克隆它
  2. 使用 Arc 使其基于计数器,
  3. 修改作业

一切都无济于事

为什么会这样?我该如何解决这个问题?

最佳答案

将闭包传递给的函数 - hyper::server::Builder::servehyper::rt::run() - 要求它们的参数是'static,而不是受任何函数的限制。 main 在这方面并不被认为是特殊的。

绑定(bind)它的值 cfg_response 被外部闭包捕获,因此嵌套闭包不是获取错误所必需的。这是一个具有相同问题的非常小的程序:

fn main() {
let cfg0 = String::from("hello world");
let cfg_response: &str = &cfg0;

let handle = move || {
// this closure takes ownership of cfg_response, a reference to cfg0. Since cfg0 will not
// outlive the function, neither can handle. If it instead took ownership of cfg0 or a
// clone of it, it would have no outside references and could live forever.
return cfg_response.to_owned();
};

serve(handle);
}

fn serve<F: Fn() -> String + 'static>(handle: F) {
loop {
println!("{}", handle());
}
}

正如@Stargateur 所指出的,这可以通过让 cfg_response 拥有来解决。

或者,您可以像这样在 lazy_static 中初始化 cfg0:

#[macro_use]
extern crate lazy_static;

lazy_static! {
static ref cfg0: String = String::from("hello world");
}

这样,您仍然可以使用借来的值,因为它符合生命周期要求。

关于rust - 嵌套闭包借用失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52397544/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com