引用捕获变量在Actix的服务器会导致“参数需要,它必须活得比“静态”

问题描述 投票:1回答:1

在下面的例子中,我有参数verbose和由命令行参数设定data_sourceverbose是一个布尔标志,但data_source用于选择来自一组,其可以根据该应用程序的数据源上使用可用功能的默认值。

Actix的使用了闭包来建立一个服务器,所以我需要得到这些参数为关闭。我加move为布尔,但我有传递使用索引的功能麻烦,我得到一生的错误。我试过拳击功能,但似乎并没有帮助。

如果我理解正确的错误信息,它实际上是没有活得比'static盖子本身。

我应该怎么做来解决这个问题?

extern crate actix;
extern crate actix_web;
extern crate env_logger;

use actix_web::http::Method;
use actix_web::{middleware, server, App, HttpRequest, HttpResponse};

enum DataSource {
    Postgres,
    HDF5,
}

fn index_postgres(req: &HttpRequest) -> HttpResponse {
    HttpResponse::Ok().body("not implemented")
}

fn index_hdf5(req: &HttpRequest) -> HttpResponse {
    HttpResponse::Ok().body("not implemented")
}

fn main() {
    let mut verbose = false;
    verbose = true;
    let mut data_source = DataSource::Postgres;
    data_source = DataSource::HDF5;

    let index = match data_source {
        DataSource::Postgres => index_postgres,
        DataSource::HDF5 => index_hdf5,
    };

    ::std::env::set_var("RUST_LOG", "actix_web=info");
    env_logger::init();
    let sys = actix::System::new("test");

    server::new(move || {
        if verbose {
            App::new()
                .middleware(middleware::Logger::default())
                .resource("/", |r| r.method(Method::GET).f(index))
        } else {
            App::new().resource("/", |r| r.method(Method::GET).f(index))
        }
    })
    .bind("127.0.0.1:8080")
    .unwrap()
    .start();

    println!("Started http server: 127.0.0.1:8080");
    let _ = sys.run();
}
error: unsatisfied lifetime constraints
  --> src\main.rs:50:13
   |
48 |       server::new(move || {
   |                   ------- lifetime `'1` represents this closure's body
49 |           if verbose {
50 | /             App::new()
51 | |                 .middleware(middleware::Logger::default())
52 | |                 .resource("/", |r| r.method(Method::GET).f(index))
   | |__________________________________________________________________^ argument requires that `'1` must outlive `'static`
   |
   = note: closure implements `Fn`, so references to captured variables can't escape the closure
rust borrow-checker
1个回答
1
投票

我不明白编译器想说的,但很明显,你需要在move封处理:

if verbose {
    App::new()
        .middleware(middleware::Logger::default())
        .resource("/", move |r| r.method(Method::GET).f(index))
} else {
    App::new().resource("/", move |r| r.method(Method::GET).f(index))
}

这是因为你需要从外部封闭index移动。

© www.soinside.com 2019 - 2024. All rights reserved.