Expand description
Little-endian large integer type 512-bits unsigned integer.
Tuple Fields
0: [u64; 8]
Implementations
sourceimpl U512
impl U512
sourcepub fn from_str_radix(txt: &str, radix: u32) -> Result<U512, FromStrRadixErr>
pub fn from_str_radix(txt: &str, radix: u32) -> Result<U512, FromStrRadixErr>
Converts a string slice in a given base to an integer. Only supports radixes of 10 and 16.
sourcepub fn from_dec_str(value: &str) -> Result<U512, FromDecStrErr>
pub fn from_dec_str(value: &str) -> Result<U512, FromDecStrErr>
Convert from a decimal string.
sourcepub fn as_u64(&self) -> u64
pub fn as_u64(&self) -> u64
Conversion to u64 with overflow checking
Panics
Panics if the number is larger than u64::max_value().
sourcepub fn as_usize(&self) -> usize
pub fn as_usize(&self) -> usize
Conversion to usize with overflow checking
Panics
Panics if the number is larger than usize::max_value().
sourcepub fn leading_zeros(&self) -> u32
pub fn leading_zeros(&self) -> u32
Returns the number of leading zeros in the binary representation of self.
sourcepub fn trailing_zeros(&self) -> u32
pub fn trailing_zeros(&self) -> u32
Returns the number of trailing zeros in the binary representation of self.
sourcepub fn to_big_endian(&self, bytes: &mut [u8])
pub fn to_big_endian(&self, bytes: &mut [u8])
Write to the slice in big-endian format.
sourcepub fn to_little_endian(&self, bytes: &mut [u8])
pub fn to_little_endian(&self, bytes: &mut [u8])
Write to the slice in little-endian format.
sourcepub fn integer_sqrt(&self) -> U512
pub fn integer_sqrt(&self) -> U512
Compute the highest n
such that n * n <= self
.
sourcepub fn pow(self, expon: U512) -> U512
pub fn pow(self, expon: U512) -> U512
Fast exponentiation by squaring https://en.wikipedia.org/wiki/Exponentiation_by_squaring
Panics
Panics if the result overflows the type.
sourcepub fn overflowing_pow(self, expon: U512) -> (U512, bool)
pub fn overflowing_pow(self, expon: U512) -> (U512, bool)
Fast exponentiation by squaring. Returns result and overflow flag.
sourcepub fn checked_pow(self, expon: U512) -> Option<U512>
pub fn checked_pow(self, expon: U512) -> Option<U512>
Checked exponentiation. Returns None
if overflow occurred.
sourcepub fn saturating_add(self, other: U512) -> U512
pub fn saturating_add(self, other: U512) -> U512
Addition which saturates at the maximum value (Self::max_value()).
sourcepub fn checked_add(self, other: U512) -> Option<U512>
pub fn checked_add(self, other: U512) -> Option<U512>
Checked addition. Returns None
if overflow occurred.
sourcepub fn overflowing_sub(self, other: U512) -> (U512, bool)
pub fn overflowing_sub(self, other: U512) -> (U512, bool)
Subtraction which underflows and returns a flag if it does.
sourcepub fn saturating_sub(self, other: U512) -> U512
pub fn saturating_sub(self, other: U512) -> U512
Subtraction which saturates at zero.
sourcepub fn checked_sub(self, other: U512) -> Option<U512>
pub fn checked_sub(self, other: U512) -> Option<U512>
Checked subtraction. Returns None
if overflow occurred.
sourcepub fn overflowing_mul(self, other: U512) -> (U512, bool)
pub fn overflowing_mul(self, other: U512) -> (U512, bool)
Multiply with overflow, returning a flag if it does.
sourcepub fn saturating_mul(self, other: U512) -> U512
pub fn saturating_mul(self, other: U512) -> U512
Multiplication which saturates at the maximum value..
sourcepub fn checked_mul(self, other: U512) -> Option<U512>
pub fn checked_mul(self, other: U512) -> Option<U512>
Checked multiplication. Returns None
if overflow occurred.
sourcepub fn checked_div(self, other: U512) -> Option<U512>
pub fn checked_div(self, other: U512) -> Option<U512>
Checked division. Returns None
if other == 0
.
sourcepub fn checked_rem(self, other: U512) -> Option<U512>
pub fn checked_rem(self, other: U512) -> Option<U512>
Checked modulus. Returns None
if other == 0
.
sourcepub fn checked_neg(self) -> Option<U512>
pub fn checked_neg(self) -> Option<U512>
Checked negation. Returns None
unless self == 0
.
Trait Implementations
sourceimpl AddAssign<U512> for U512
impl AddAssign<U512> for U512
sourcepub fn add_assign(&mut self, other: U512)
pub fn add_assign(&mut self, other: U512)
Performs the +=
operation. Read more
sourceimpl Decode for U512
impl Decode for U512
sourcepub fn decode<I>(input: &mut I) -> Result<U512, Error> where
I: Input,
pub fn decode<I>(input: &mut I) -> Result<U512, Error> where
I: Input,
Attempt to deserialise the value from input.
sourcefn skip<I>(input: &mut I) -> Result<(), Error> where
I: Input,
fn skip<I>(input: &mut I) -> Result<(), Error> where
I: Input,
Attempt to skip the encoded value from input. Read more
sourcefn encoded_fixed_size() -> Option<usize>
fn encoded_fixed_size() -> Option<usize>
Returns the fixed encoded size of the type. Read more
sourceimpl<'de> Deserialize<'de> for U512
impl<'de> Deserialize<'de> for U512
sourcepub fn deserialize<D>(
deserializer: D
) -> Result<U512, <D as Deserializer<'de>>::Error> where
D: Deserializer<'de>,
pub fn deserialize<D>(
deserializer: D
) -> Result<U512, <D as Deserializer<'de>>::Error> where
D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
sourceimpl<T> DivAssign<T> for U512 where
T: Into<U512>,
impl<T> DivAssign<T> for U512 where
T: Into<U512>,
sourcepub fn div_assign(&mut self, other: T)
pub fn div_assign(&mut self, other: T)
Performs the /=
operation. Read more
sourceimpl Encode for U512
impl Encode for U512
sourcepub fn using_encoded<R, F>(&self, f: F) -> R where
F: FnOnce(&[u8]) -> R,
pub fn using_encoded<R, F>(&self, f: F) -> R where
F: FnOnce(&[u8]) -> R,
Convert self to a slice and then invoke the given closure with it.
sourcefn size_hint(&self) -> usize
fn size_hint(&self) -> usize
If possible give a hint of expected size of the encoding. Read more
sourcefn encode_to<T>(&self, dest: &mut T) where
T: Output + ?Sized,
fn encode_to<T>(&self, dest: &mut T) where
T: Output + ?Sized,
Convert self to a slice and append it to the destination.
sourcefn encode(&self) -> Vec<u8, Global>ⓘNotable traits for Vec<u8, A>impl<A> Write for Vec<u8, A> where
A: Allocator,
fn encode(&self) -> Vec<u8, Global>ⓘNotable traits for Vec<u8, A>impl<A> Write for Vec<u8, A> where
A: Allocator,
A: Allocator,
Convert self to an owned vector.
sourcefn encoded_size(&self) -> usize
fn encoded_size(&self) -> usize
Calculates the encoded size. Read more
sourceimpl MallocSizeOf for U512
impl MallocSizeOf for U512
sourcepub fn size_of(&self, &mut MallocSizeOfOps) -> usize
pub fn size_of(&self, &mut MallocSizeOfOps) -> usize
Measure the heap usage of all descendant heap-allocated structures, but
not the space taken up by the value itself.
If T::size_of
is a constant, consider implementing constant_size
as well. Read more
sourcepub fn constant_size() -> Option<usize>
pub fn constant_size() -> Option<usize>
Used to optimize MallocSizeOf
implementation for collections
like Vec
and HashMap
to avoid iterating over them unnecessarily.
The Self: Sized
bound is for object safety. Read more
sourceimpl MaxEncodedLen for U512
impl MaxEncodedLen for U512
sourcepub fn max_encoded_len() -> usize
pub fn max_encoded_len() -> usize
Upper bound, in bytes, of the maximum encoded size of this item.
sourceimpl MulAssign<U512> for U512
impl MulAssign<U512> for U512
sourcepub fn mul_assign(&mut self, other: U512)
pub fn mul_assign(&mut self, other: U512)
Performs the *=
operation. Read more
sourceimpl MulAssign<i16> for U512
impl MulAssign<i16> for U512
sourcepub fn mul_assign(&mut self, other: i16)
pub fn mul_assign(&mut self, other: i16)
Performs the *=
operation. Read more
sourceimpl MulAssign<i32> for U512
impl MulAssign<i32> for U512
sourcepub fn mul_assign(&mut self, other: i32)
pub fn mul_assign(&mut self, other: i32)
Performs the *=
operation. Read more
sourceimpl MulAssign<i64> for U512
impl MulAssign<i64> for U512
sourcepub fn mul_assign(&mut self, other: i64)
pub fn mul_assign(&mut self, other: i64)
Performs the *=
operation. Read more
sourceimpl MulAssign<i8> for U512
impl MulAssign<i8> for U512
sourcepub fn mul_assign(&mut self, other: i8)
pub fn mul_assign(&mut self, other: i8)
Performs the *=
operation. Read more
sourceimpl MulAssign<isize> for U512
impl MulAssign<isize> for U512
sourcepub fn mul_assign(&mut self, other: isize)
pub fn mul_assign(&mut self, other: isize)
Performs the *=
operation. Read more
sourceimpl MulAssign<u16> for U512
impl MulAssign<u16> for U512
sourcepub fn mul_assign(&mut self, other: u16)
pub fn mul_assign(&mut self, other: u16)
Performs the *=
operation. Read more
sourceimpl MulAssign<u32> for U512
impl MulAssign<u32> for U512
sourcepub fn mul_assign(&mut self, other: u32)
pub fn mul_assign(&mut self, other: u32)
Performs the *=
operation. Read more
sourceimpl MulAssign<u64> for U512
impl MulAssign<u64> for U512
sourcepub fn mul_assign(&mut self, other: u64)
pub fn mul_assign(&mut self, other: u64)
Performs the *=
operation. Read more
sourceimpl MulAssign<u8> for U512
impl MulAssign<u8> for U512
sourcepub fn mul_assign(&mut self, other: u8)
pub fn mul_assign(&mut self, other: u8)
Performs the *=
operation. Read more
sourceimpl MulAssign<usize> for U512
impl MulAssign<usize> for U512
sourcepub fn mul_assign(&mut self, other: usize)
pub fn mul_assign(&mut self, other: usize)
Performs the *=
operation. Read more
sourceimpl Ord for U512
impl Ord for U512
sourceimpl PartialOrd<U512> for U512
impl PartialOrd<U512> for U512
sourcepub fn partial_cmp(&self, other: &U512) -> Option<Ordering>
pub fn partial_cmp(&self, other: &U512) -> Option<Ordering>
This method returns an ordering between self
and other
values if one exists. Read more
1.0.0 · sourcefn lt(&self, other: &Rhs) -> bool
fn lt(&self, other: &Rhs) -> bool
This method tests less than (for self
and other
) and is used by the <
operator. Read more
1.0.0 · sourcefn le(&self, other: &Rhs) -> bool
fn le(&self, other: &Rhs) -> bool
This method tests less than or equal to (for self
and other
) and is used by the <=
operator. Read more
sourceimpl<T> RemAssign<T> for U512 where
T: Into<U512> + Copy,
impl<T> RemAssign<T> for U512 where
T: Into<U512> + Copy,
sourcepub fn rem_assign(&mut self, other: T)
pub fn rem_assign(&mut self, other: T)
Performs the %=
operation. Read more
sourceimpl Serialize for U512
impl Serialize for U512
sourcepub fn serialize<S>(
&self,
serializer: S
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error> where
S: Serializer,
pub fn serialize<S>(
&self,
serializer: S
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error> where
S: Serializer,
Serialize this value into the given Serde serializer. Read more
sourceimpl<T> ShlAssign<T> for U512 where
T: Into<U512>,
impl<T> ShlAssign<T> for U512 where
T: Into<U512>,
sourcepub fn shl_assign(&mut self, shift: T)
pub fn shl_assign(&mut self, shift: T)
Performs the <<=
operation. Read more
sourceimpl<T> ShrAssign<T> for U512 where
T: Into<U512>,
impl<T> ShrAssign<T> for U512 where
T: Into<U512>,
sourcepub fn shr_assign(&mut self, shift: T)
pub fn shr_assign(&mut self, shift: T)
Performs the >>=
operation. Read more
sourceimpl SubAssign<U512> for U512
impl SubAssign<U512> for U512
sourcepub fn sub_assign(&mut self, other: U512)
pub fn sub_assign(&mut self, other: U512)
Performs the -=
operation. Read more
impl Copy for U512
impl EncodeLike<U512> for U512
impl Eq for U512
impl StructuralEq for U512
impl StructuralPartialEq for U512
Auto Trait Implementations
impl RefUnwindSafe for U512
impl Send for U512
impl Sync for U512
impl Unpin for U512
impl UnwindSafe for U512
Blanket Implementations
sourceimpl<T, U> AsByteSlice<T> for U where
T: ToByteSlice,
U: AsRef<[T]> + ?Sized,
impl<T, U> AsByteSlice<T> for U where
T: ToByteSlice,
U: AsRef<[T]> + ?Sized,
sourceimpl<T> BorrowMut<T> for T where
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
const: unstable · sourcepub fn borrow_mut(&mut self) -> &mut T
pub fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
sourceimpl<T> CallHasher for T where
T: Hash,
impl<T> CallHasher for T where
T: Hash,
sourceimpl<T> DecodeLimit for T where
T: Decode,
impl<T> DecodeLimit for T where
T: Decode,
sourceimpl<T> Instrument for T
impl<T> Instrument for T
sourcefn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Instruments this type with the provided Span
, returning an
Instrumented
wrapper. Read more
sourcefn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
sourceimpl<T, Outer> IsWrappedBy<Outer> for T where
Outer: AsRef<T> + AsMut<T> + From<T>,
T: From<Outer>,
impl<T, Outer> IsWrappedBy<Outer> for T where
Outer: AsRef<T> + AsMut<T> + From<T>,
T: From<Outer>,
sourceimpl<T> MallocSizeOfExt for T where
T: MallocSizeOf,
impl<T> MallocSizeOfExt for T where
T: MallocSizeOf,
sourcefn malloc_size_of(&self) -> usize
fn malloc_size_of(&self) -> usize
Method to launch a heapsize measurement with a fresh state. Read more
sourceimpl<T> ToOwned for T where
T: Clone,
impl<T> ToOwned for T where
T: Clone,
type Owned = T
type Owned = T
The resulting type after obtaining ownership.
sourcepub fn to_owned(&self) -> T
pub fn to_owned(&self) -> T
Creates owned data from borrowed data, usually by cloning. Read more
sourcepub fn clone_into(&self, target: &mut T)
pub fn clone_into(&self, target: &mut T)
toowned_clone_into
)Uses borrowed data to replace owned data, usually by cloning. Read more
sourceimpl<S, T> UncheckedInto<T> for S where
T: UncheckedFrom<S>,
impl<S, T> UncheckedInto<T> for S where
T: UncheckedFrom<S>,
sourcefn unchecked_into(self) -> T
fn unchecked_into(self) -> T
The counterpart to unchecked_from
.