我目前正在听这个问题。我试图将其缩小到最小的可重现示例。
struct Request;
struct ResponseWriter<'a> {
dummy: &'a ()
}
#[deriving(Clone)]
pub struct RouteStore{
pub routes: Vec<Route>,
}
#[deriving(Clone)]
struct Route {
path: String,
handler: fn(request: &Request, response: &mut ResponseWriter)
}
impl RouteStore {
pub fn new () -> RouteStore {
RouteStore {
routes: Vec::new()
}
}
fn add_route (&mut self, path: String, handler: fn(request: &Request, response: &mut ResponseWriter)) -> () {
let route = Route {
path: path,
handler: handler
};
self.routes.push(route);
}
}
fn main () {
}
这给我留下了:
error: mismatched types: expected `fn(&http::server::request::Request, &mut http::server::response::ResponseWriter<>)` but found `fn(&http::server::request::Request, &mut http::server::response::ResponseWriter<>)` (expected concrete lifetime, but found bound lifetime parameter )
src/so.rs:12 handler: fn(request: &Request, response: &mut ResponseWriter)
^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
之前我存储了我的fn
in a HashMap
像这样HashMap<String, fn(request: &Request, response: &mut ResponseWriter)>
。这很好用。
但现在我想重构一下并引入一个Route
将事物构造并存储为Vec<Route>
。但突然间地狱崩溃了,我不知道如何解决它:-/
对于好奇的人来说,这是我为 Rust 编写一个受expressjs启发的Web框架的一部分Floor https://github.com/cburgdorf/Floor