Tipos de Dados Genéricos
VocĂȘ pode usar genĂ©ricos para abstrair o tipo concreto do campo:
#[derive(Debug)] struct Point<T> { x: T, y: T, } impl<T> Point<T> { fn coords(&self) -> (&T, &T) { (&self.x, &self.y) } fn set_x(&mut self, x: T) { self.x = x; } } fn main() { let integer = Point { x: 5, y: 10 }; let float = Point { x: 1.0, y: 4.0 }; println!("{integer:?} e {float:?}"); println!("coords: {:?}", integer.coords()); }
This slide should take about 10 minutes.
-
Pergunta: Por que
T
Ă© especificado duas vezes emimpl<T> Point<T> {}
? Isso não é redundante?- Isso ocorre porque é uma seção de implementação genérica para tipo genérico. Eles são genéricos de forma independente.
- Significa que esses métodos são definidos para qualquer
T
. - Ă possĂvel escrever
impl Point<u32> { .. }
.Point
ainda Ă© genĂ©rico e vocĂȘ pode usarPoint<f64>
, mas os mĂ©todos neste bloco sĂł estarĂŁo disponĂveis paraPoint<u32>
.
-
Tente declarar uma nova variĂĄvel
let p = Point { x: 5, y: 10.0 };
. Atualize o cĂłdigo para permitir pontos que tenham elementos de tipos diferentes, usando duas variĂĄveis de tipo, por exemplo,T
eU
.