我写了以下代码:
use std::io::{IoResult, Writer};
use std::io::stdio;
fn main() {
let h = |&: w: &mut Writer| -> IoResult<()> {
writeln!(w, "foo")
};
let _ = h.handle(&mut stdio::stdout());
}
trait Handler<W> where W: Writer {
fn handle(&self, &mut W) -> IoResult<()>;
}
impl<W, F> Handler<W> for F
where W: Writer, F: Fn(&mut W) -> IoResult<()> {
fn handle(&self, w: &mut W) -> IoResult<()> { (*self)(w) }
}
Run Code Online (Sandbox Code Playgroud)
然后rustc在我的终端:
$ rustc writer_handler.rs
writer_handler.rs:8:15: 8:43 error: the trait `core::marker::Sized` is not …Run Code Online (Sandbox Code Playgroud) 它是否创建一个新线程然后在新线程中执行该匿名函数?
当我使用闭包时,我注意到许多所有权/借用限制.例如,如果我有Fn(),我不能在闭包内传递一个可变变量,或者它需要用一个包裹Mutex:
fn helloworld(f: &Fn(f64)) {
f(42f64);
}
pub fn main() {
let mut killer = 2;
helloworld(&|n| {
println!("{}", n);
killer += 1;
});
}
Run Code Online (Sandbox Code Playgroud)
如果一个闭包可能不安全,那么场景后面会发生异步或并行的事情,这就是为什么Rust编译器不允许我编译这样的代码.
我可能会感到困惑,因为我来自JavaScript/Python世界,那里的情况完全不同.
rust-ini有一个功能:
pub fn section<'a, S>(&'a self, name: Option<S>) -> Option<&'a Properties>
where S: Into<String>
Run Code Online (Sandbox Code Playgroud)
我想读一个没有节的文件,所以我这样称呼它:
let ifo_cfg = match Ini::load_from_file("conf.ini") {
Result::Ok(cfg) => cfg,
Result::Err(err) => return Result::Err(err.msg),
};
let section = ifo_cfg.section(None).unwrap();
Run Code Online (Sandbox Code Playgroud)
但它给出了编译错误:
无法推断出足够的类型信息
_; 需要输入注释或通用参数绑定[E0282]
我可以像这样解决它:
let none: Option<String> = None;
let section = ifo_cfg.section(none).unwrap();
Run Code Online (Sandbox Code Playgroud)
如何在没有附加线的情况下解决这个问题none?