Operadores
A sobrecarga de operadores Ă© implementada por meio do trait
contido em std::ops
:
#[derive(Debug, Copy, Clone)] struct Point { x: i32, y: i32, } impl std::ops::Add for Point { type Output = Self; fn add(self, other: Self) -> Self { Self { x: self.x + other.x, y: self.y + other.y } } } fn main() { let p1 = Point { x: 10, y: 20 }; let p2 = Point { x: 100, y: 200 }; println!("{:?} + {:?} = {:?}", p1, p2, p1 + p2); }
This slide should take about 5 minutes.
Pontos de discussĂŁo:
- VocĂȘ pode implementar
Add
para&Point
. Em quais situaçÔes isso Ă© Ăștil?- Resposta:
Add:add
consomeself
. Se o tipoT
para o qual vocĂȘ estĂĄ sobrecarregando o operador nĂŁo implementaCopy
, vocĂȘ deve considerar sobrecarregar o operador para&T
também. Isso evita a clonagem desnecessåria no local da chamada.
- Resposta:
- Por que
Output
é um tipo associado? Poderia ser feito um parùmetro de tipo do método?- Resposta curta: os parùmetros de tipo de função são controlados pelo chamador, mas os tipos associados (como
Output
) sĂŁo controlados pelo implementador de umtrait
.
- Resposta curta: os parùmetros de tipo de função são controlados pelo chamador, mas os tipos associados (como
- VocĂȘ pode implementar
Add
para dois tipos diferentes, por exemplo,impl Add<(i32, i32)> for Point
adicionaria uma tupla a umPoint
.