Expand description
The remainder operator %
.
Note that Rhs
is Self
by default, but this is not mandatory.
Examples
This example implements Rem
on a SplitSlice
object. After Rem
is
implemented, one can use the %
operator to find out what the remaining
elements of the slice would be after splitting it into equal slices of a
given length.
use std::ops::Rem;
#[derive(PartialEq, Debug)]
struct SplitSlice<'a, T: 'a> {
slice: &'a [T],
}
impl<'a, T> Rem<usize> for SplitSlice<'a, T> {
type Output = Self;
fn rem(self, modulus: usize) -> Self::Output {
let len = self.slice.len();
let rem = len % modulus;
let start = len - rem;
Self {slice: &self.slice[start..]}
}
}
// If we were to divide &[0, 1, 2, 3, 4, 5, 6, 7] into slices of size 3,
// the remainder would be &[6, 7].
assert_eq!(SplitSlice { slice: &[0, 1, 2, 3, 4, 5, 6, 7] } % 3,
SplitSlice { slice: &[6, 7] });
RunAssociated Types
Required methods
Implementors
type Output = <Saturating<i8> as Rem<Saturating<i8>>>::Output
type Output = <Saturating<i8> as Rem<Saturating<i8>>>::Output
type Output = <Saturating<i16> as Rem<Saturating<i16>>>::Output
type Output = <Saturating<i16> as Rem<Saturating<i16>>>::Output
type Output = <Saturating<i32> as Rem<Saturating<i32>>>::Output
type Output = <Saturating<i32> as Rem<Saturating<i32>>>::Output
type Output = <Saturating<i64> as Rem<Saturating<i64>>>::Output
type Output = <Saturating<i64> as Rem<Saturating<i64>>>::Output
type Output = <Saturating<i128> as Rem<Saturating<i128>>>::Output
type Output = <Saturating<i128> as Rem<Saturating<i128>>>::Output
type Output = <Saturating<isize> as Rem<Saturating<isize>>>::Output
type Output = <Saturating<isize> as Rem<Saturating<isize>>>::Output
type Output = <Saturating<u8> as Rem<Saturating<u8>>>::Output
type Output = <Saturating<u8> as Rem<Saturating<u8>>>::Output
type Output = <Saturating<u16> as Rem<Saturating<u16>>>::Output
type Output = <Saturating<u16> as Rem<Saturating<u16>>>::Output
type Output = <Saturating<u32> as Rem<Saturating<u32>>>::Output
type Output = <Saturating<u32> as Rem<Saturating<u32>>>::Output
type Output = <Saturating<u64> as Rem<Saturating<u64>>>::Output
type Output = <Saturating<u64> as Rem<Saturating<u64>>>::Output
type Output = <Saturating<u128> as Rem<Saturating<u128>>>::Output
type Output = <Saturating<u128> as Rem<Saturating<u128>>>::Output
type Output = <Saturating<usize> as Rem<Saturating<usize>>>::Output
type Output = <Saturating<usize> as Rem<Saturating<usize>>>::Output
The remainder from the division of two floats.
The remainder has the same sign as the dividend and is computed as:
x - (x / y).trunc() * y
.
Examples
let x: f32 = 50.50;
let y: f32 = 8.125;
let remainder = x - (x / y).trunc() * y;
// The answer to both operations is 1.75
assert_eq!(x % y, remainder);
RunThe remainder from the division of two floats.
The remainder has the same sign as the dividend and is computed as:
x - (x / y).trunc() * y
.
Examples
let x: f32 = 50.50;
let y: f32 = 8.125;
let remainder = x - (x / y).trunc() * y;
// The answer to both operations is 1.75
assert_eq!(x % y, remainder);
RunThis operation satisfies n % d == n - (n / d) * d
. The
result has the same sign as the left operand.
Panics
This operation will panic if other == 0
or if self / other
results in overflow.
type Output = Saturating<i8>
This operation satisfies n % d == n - (n / d) * d
. The
result has the same sign as the left operand.
Panics
This operation will panic if other == 0
or if self / other
results in overflow.
type Output = Saturating<i16>
This operation satisfies n % d == n - (n / d) * d
. The
result has the same sign as the left operand.
Panics
This operation will panic if other == 0
or if self / other
results in overflow.
type Output = Saturating<i32>
This operation satisfies n % d == n - (n / d) * d
. The
result has the same sign as the left operand.
Panics
This operation will panic if other == 0
or if self / other
results in overflow.
type Output = Saturating<i64>
This operation satisfies n % d == n - (n / d) * d
. The
result has the same sign as the left operand.
Panics
This operation will panic if other == 0
or if self / other
results in overflow.
type Output = Saturating<i128>
This operation satisfies n % d == n - (n / d) * d
. The
result has the same sign as the left operand.
Panics
This operation will panic if other == 0
or if self / other
results in overflow.
type Output = Saturating<isize>
This operation satisfies n % d == n - (n / d) * d
. The
result has the same sign as the left operand.
Panics
This operation will panic if other == 0
.
type Output = Saturating<u8>
This operation satisfies n % d == n - (n / d) * d
. The
result has the same sign as the left operand.
Panics
This operation will panic if other == 0
.
type Output = Saturating<u16>
This operation satisfies n % d == n - (n / d) * d
. The
result has the same sign as the left operand.
Panics
This operation will panic if other == 0
.
type Output = Saturating<u32>
This operation satisfies n % d == n - (n / d) * d
. The
result has the same sign as the left operand.
Panics
This operation will panic if other == 0
.
type Output = Saturating<u64>
This operation satisfies n % d == n - (n / d) * d
. The
result has the same sign as the left operand.
Panics
This operation will panic if other == 0
.
type Output = Saturating<u128>
This operation satisfies n % d == n - (n / d) * d
. The
result has the same sign as the left operand.
Panics
This operation will panic if other == 0
.