Podczas pisania kodu z cech można umieścić cechę w cecha związana:Jaka jest różnica między <T: Trait> Box <T> i & Trait/Box <Trait>?
use std::fmt::Debug;
fn myfunction1<T: Debug>(v: Box<T>) {
println!("{:?}", v);
}
fn myfunction2<T: Debug>(v: &T) {
println!("{:?}", v);
}
fn main() {
myfunction1(Box::new(5));
myfunction2(&5);
}
lub bezpośrednio w rodzaju Box
lub odniesienia:
use std::fmt::Debug;
fn myfunction3(v: Box<Debug>) {
println!("{:?}", v);
}
fn myfunction4(v: &Debug) {
println!("{:?}", v);
}
fn main() {
myfunction3(Box::new(5));
myfunction4(&5);
}
one dają ten sam wynik. Jaka jest różnica?
(ta kwestia była inspirowana przez another question gdzie to tylko jeden z kilku wymieszanych pojęć)