Trait sp_std::ops::Add 1.0.0[−][src]
The addition operator +.
Note that Rhs is Self by default, but this is not mandatory. For
example, std::time::SystemTime implements Add<Duration>, which permits
operations of the form SystemTime = SystemTime + Duration.
Examples
Addable points
use std::ops::Add; #[derive(Debug, Copy, Clone, PartialEq)] struct Point { x: i32, y: i32, } impl Add for Point { type Output = Self; fn add(self, other: Self) -> Self { Self { x: self.x + other.x, y: self.y + other.y, } } } assert_eq!(Point { x: 1, y: 0 } + Point { x: 2, y: 3 }, Point { x: 3, y: 3 });
Implementing Add with generics
Here is an example of the same Point struct implementing the Add trait
using generics.
use std::ops::Add; #[derive(Debug, Copy, Clone, PartialEq)] struct Point<T> { x: T, y: T, } // Notice that the implementation uses the associated type `Output`. impl<T: Add<Output = T>> Add for Point<T> { type Output = Self; fn add(self, other: Self) -> Self::Output { Self { x: self.x + other.x, y: self.y + other.y, } } } assert_eq!(Point { x: 1, y: 0 } + Point { x: 2, y: 3 }, Point { x: 3, y: 3 });
Associated Types
Loading content...Required methods
Loading content...Implementations on Foreign Types
impl Add<Duration> for SystemTime[src]
impl Add<Duration> for SystemTime[src]type Output = SystemTime
pub fn add(self, dur: Duration) -> SystemTime[src]
Panics
This function may panic if the resulting point in time cannot be represented by the
underlying data structure. See SystemTime::checked_add for a version without panic.
impl Add<Duration> for Instant[src]
impl Add<Duration> for Instant[src]impl<'_, '_> Add<&'_ u8> for &'_ u8[src]
impl<'_, '_> Add<&'_ u8> for &'_ u8[src]impl<'a> Add<f32> for &'a f32[src]
impl<'a> Add<f32> for &'a f32[src]impl<'a> Add<i64> for &'a i64[src]
impl<'a> Add<i64> for &'a i64[src]impl<'a> Add<isize> for &'a isize[src]
impl<'a> Add<isize> for &'a isize[src]impl<'a> Add<u64> for &'a u64[src]
impl<'a> Add<u64> for &'a u64[src]impl<'_, '_> Add<&'_ i8> for &'_ i8[src]
impl<'_, '_> Add<&'_ i8> for &'_ i8[src]impl<'a> Add<u16> for &'a u16[src]
impl<'a> Add<u16> for &'a u16[src]impl<'a> Add<usize> for &'a usize[src]
impl<'a> Add<usize> for &'a usize[src]impl<'_, '_> Add<&'_ i64> for &'_ i64[src]
impl<'_, '_> Add<&'_ i64> for &'_ i64[src]impl<'_> Add<&'_ i128> for i128[src]
impl<'_> Add<&'_ i128> for i128[src]impl<'_> Add<&'_ u32> for u32[src]
impl<'_> Add<&'_ u32> for u32[src]impl<'a> Add<i8> for &'a i8[src]
impl<'a> Add<i8> for &'a i8[src]impl<'_, '_> Add<&'_ u128> for &'_ u128[src]
impl<'_, '_> Add<&'_ u128> for &'_ u128[src]impl<'_> Add<&'_ i16> for i16[src]
impl<'_> Add<&'_ i16> for i16[src]impl<'_> Add<&'_ usize> for usize[src]
impl<'_> Add<&'_ usize> for usize[src]impl<'_> Add<&'_ u128> for u128[src]
impl<'_> Add<&'_ u128> for u128[src]impl<'a> Add<i16> for &'a i16[src]
impl<'a> Add<i16> for &'a i16[src]impl<'_> Add<&'_ i32> for i32[src]
impl<'_> Add<&'_ i32> for i32[src]impl<'_> Add<&'_ i8> for i8[src]
impl<'_> Add<&'_ i8> for i8[src]impl<'a> Add<i128> for &'a i128[src]
impl<'a> Add<i128> for &'a i128[src]impl<'_, '_> Add<&'_ u32> for &'_ u32[src]
impl<'_, '_> Add<&'_ u32> for &'_ u32[src]impl<'_> Add<&'_ i64> for i64[src]
impl<'_> Add<&'_ i64> for i64[src]impl<'_, '_> Add<&'_ i32> for &'_ i32[src]
impl<'_, '_> Add<&'_ i32> for &'_ i32[src]impl<'_> Add<&'_ u16> for u16[src]
impl<'_> Add<&'_ u16> for u16[src]impl<'_, '_> Add<&'_ u64> for &'_ u64[src]
impl<'_, '_> Add<&'_ u64> for &'_ u64[src]impl<'_> Add<&'_ f64> for f64[src]
impl<'_> Add<&'_ f64> for f64[src]impl<'_, '_> Add<&'_ f32> for &'_ f32[src]
impl<'_, '_> Add<&'_ f32> for &'_ f32[src]impl<'_> Add<&'_ f32> for f32[src]
impl<'_> Add<&'_ f32> for f32[src]impl<'a> Add<u32> for &'a u32[src]
impl<'a> Add<u32> for &'a u32[src]impl<'_> Add<&'_ u8> for u8[src]
impl<'_> Add<&'_ u8> for u8[src]impl<'_> Add<&'_ u64> for u64[src]
impl<'_> Add<&'_ u64> for u64[src]impl<'a> Add<i32> for &'a i32[src]
impl<'a> Add<i32> for &'a i32[src]impl<'_, '_> Add<&'_ f64> for &'_ f64[src]
impl<'_, '_> Add<&'_ f64> for &'_ f64[src]impl<'_, '_> Add<&'_ u16> for &'_ u16[src]
impl<'_, '_> Add<&'_ u16> for &'_ u16[src]impl<'a> Add<u128> for &'a u128[src]
impl<'a> Add<u128> for &'a u128[src]impl<'a> Add<f64> for &'a f64[src]
impl<'a> Add<f64> for &'a f64[src]impl<'_, '_> Add<&'_ usize> for &'_ usize[src]
impl<'_, '_> Add<&'_ usize> for &'_ usize[src]impl<'a> Add<u8> for &'a u8[src]
impl<'a> Add<u8> for &'a u8[src]impl<'_> Add<&'_ isize> for isize[src]
impl<'_> Add<&'_ isize> for isize[src]impl<'_, '_> Add<&'_ i16> for &'_ i16[src]
impl<'_, '_> Add<&'_ i16> for &'_ i16[src]impl<'_, '_> Add<&'_ isize> for &'_ isize[src]
impl<'_, '_> Add<&'_ isize> for &'_ isize[src]impl Add<Duration> for Duration[src]
impl Add<Duration> for Duration[src]impl<'_, '_> Add<&'_ i128> for &'_ i128[src]
impl<'_, '_> Add<&'_ i128> for &'_ i128[src]impl<'_> Add<&'_ str> for String[src]
impl<'_> Add<&'_ str> for String[src]Implements the + operator for concatenating two strings.
This consumes the String on the left-hand side and re-uses its buffer (growing it if
necessary). This is done to avoid allocating a new String and copying the entire contents on
every operation, which would lead to O(n^2) running time when building an n-byte string by
repeated concatenation.
The string on the right-hand side is only borrowed; its contents are copied into the returned
String.
Examples
Concatenating two Strings takes the first by value and borrows the second:
let a = String::from("hello"); let b = String::from(" world"); let c = a + &b; // `a` is moved and can no longer be used here.
If you want to keep using the first String, you can clone it and append to the clone instead:
let a = String::from("hello"); let b = String::from(" world"); let c = a.clone() + &b; // `a` is still valid here.
Concatenating &str slices can be done by converting the first to a String:
let a = "hello"; let b = " world"; let c = a.to_string() + b;