Struct ethereum_types::U64
source · #[repr(C)]pub struct U64(pub [u64; 1]);Expand description
Little-endian large integer type Unsigned 64-bit integer.
Tuple Fields§
§0: [u64; 1]Implementations§
source§impl U64
impl U64
sourcepub fn from_dec_str(value: &str) -> Result<Self, FromDecStrErr>
pub fn from_dec_str(value: &str) -> Result<Self, 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 leading 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 div_mod(self, other: Self) -> (Self, Self)
pub fn div_mod(self, other: Self) -> (Self, Self)
sourcepub fn pow(self, expon: Self) -> Self
pub fn pow(self, expon: Self) -> Self
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: Self) -> (Self, bool)
pub fn overflowing_pow(self, expon: Self) -> (Self, bool)
Fast exponentiation by squaring. Returns result and overflow flag.
sourcepub fn checked_pow(self, expon: U64) -> Option<U64>
pub fn checked_pow(self, expon: U64) -> Option<U64>
Checked exponentiation. Returns None if overflow occurred.
sourcepub fn overflowing_add(self, other: U64) -> (U64, bool)
pub fn overflowing_add(self, other: U64) -> (U64, bool)
Add with overflow.
sourcepub fn saturating_add(self, other: U64) -> U64
pub fn saturating_add(self, other: U64) -> U64
Addition which saturates at the maximum value (Self::max_value()).
sourcepub fn checked_add(self, other: U64) -> Option<U64>
pub fn checked_add(self, other: U64) -> Option<U64>
Checked addition. Returns None if overflow occurred.
sourcepub fn overflowing_sub(self, other: U64) -> (U64, bool)
pub fn overflowing_sub(self, other: U64) -> (U64, bool)
Subtraction which underflows and returns a flag if it does.
sourcepub fn saturating_sub(self, other: U64) -> U64
pub fn saturating_sub(self, other: U64) -> U64
Subtraction which saturates at zero.
sourcepub fn checked_sub(self, other: U64) -> Option<U64>
pub fn checked_sub(self, other: U64) -> Option<U64>
Checked subtraction. Returns None if overflow occurred.
sourcepub fn overflowing_mul(self, other: U64) -> (U64, bool)
pub fn overflowing_mul(self, other: U64) -> (U64, bool)
Multiply with overflow, returning a flag if it does.
sourcepub fn saturating_mul(self, other: U64) -> U64
pub fn saturating_mul(self, other: U64) -> U64
Multiplication which saturates at the maximum value..
sourcepub fn checked_mul(self, other: U64) -> Option<U64>
pub fn checked_mul(self, other: U64) -> Option<U64>
Checked multiplication. Returns None if overflow occurred.
sourcepub fn checked_div(self, other: U64) -> Option<U64>
pub fn checked_div(self, other: U64) -> Option<U64>
Checked division. Returns None if other == 0.
sourcepub fn checked_rem(self, other: U64) -> Option<U64>
pub fn checked_rem(self, other: U64) -> Option<U64>
Checked modulus. Returns None if other == 0.
sourcepub fn overflowing_neg(self) -> (U64, bool)
pub fn overflowing_neg(self) -> (U64, bool)
Negation with overflow.
sourcepub fn checked_neg(self) -> Option<U64>
pub fn checked_neg(self) -> Option<U64>
Checked negation. Returns None unless self == 0.
sourcepub fn from_big_endian(slice: &[u8]) -> Self
pub fn from_big_endian(slice: &[u8]) -> Self
Converts from big endian representation bytes in memory.
sourcepub fn from_little_endian(slice: &[u8]) -> Self
pub fn from_little_endian(slice: &[u8]) -> Self
Converts from little endian representation bytes in memory.
Trait Implementations§
source§impl AddAssign for U64
impl AddAssign for U64
source§fn add_assign(&mut self, other: U64)
fn add_assign(&mut self, other: U64)
+= operation. Read moresource§impl<'de> Deserialize<'de> for U64
impl<'de> Deserialize<'de> for U64
source§fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>where
D: Deserializer<'de>,
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>where
D: Deserializer<'de>,
source§impl<T> DivAssign<T> for U64
impl<T> DivAssign<T> for U64
source§fn div_assign(&mut self, other: T)
fn div_assign(&mut self, other: T)
/= operation. Read moresource§impl MulAssign<i16> for U64
impl MulAssign<i16> for U64
source§fn mul_assign(&mut self, other: i16)
fn mul_assign(&mut self, other: i16)
*= operation. Read moresource§impl MulAssign<i32> for U64
impl MulAssign<i32> for U64
source§fn mul_assign(&mut self, other: i32)
fn mul_assign(&mut self, other: i32)
*= operation. Read moresource§impl MulAssign<i64> for U64
impl MulAssign<i64> for U64
source§fn mul_assign(&mut self, other: i64)
fn mul_assign(&mut self, other: i64)
*= operation. Read moresource§impl MulAssign<i8> for U64
impl MulAssign<i8> for U64
source§fn mul_assign(&mut self, other: i8)
fn mul_assign(&mut self, other: i8)
*= operation. Read moresource§impl MulAssign<isize> for U64
impl MulAssign<isize> for U64
source§fn mul_assign(&mut self, other: isize)
fn mul_assign(&mut self, other: isize)
*= operation. Read moresource§impl MulAssign<u16> for U64
impl MulAssign<u16> for U64
source§fn mul_assign(&mut self, other: u16)
fn mul_assign(&mut self, other: u16)
*= operation. Read moresource§impl MulAssign<u32> for U64
impl MulAssign<u32> for U64
source§fn mul_assign(&mut self, other: u32)
fn mul_assign(&mut self, other: u32)
*= operation. Read moresource§impl MulAssign<u64> for U64
impl MulAssign<u64> for U64
source§fn mul_assign(&mut self, other: u64)
fn mul_assign(&mut self, other: u64)
*= operation. Read moresource§impl MulAssign<u8> for U64
impl MulAssign<u8> for U64
source§fn mul_assign(&mut self, other: u8)
fn mul_assign(&mut self, other: u8)
*= operation. Read moresource§impl MulAssign<usize> for U64
impl MulAssign<usize> for U64
source§fn mul_assign(&mut self, other: usize)
fn mul_assign(&mut self, other: usize)
*= operation. Read moresource§impl MulAssign for U64
impl MulAssign for U64
source§fn mul_assign(&mut self, other: U64)
fn mul_assign(&mut self, other: U64)
*= operation. Read moresource§impl Ord for U64
impl Ord for U64
source§impl PartialOrd for U64
impl PartialOrd for U64
1.0.0 · source§fn le(&self, other: &Rhs) -> bool
fn le(&self, other: &Rhs) -> bool
self and other) and is used by the <=
operator. Read moresource§impl<T> RemAssign<T> for U64
impl<T> RemAssign<T> for U64
source§fn rem_assign(&mut self, other: T)
fn rem_assign(&mut self, other: T)
%= operation. Read moresource§impl<T> ShlAssign<T> for U64
impl<T> ShlAssign<T> for U64
source§fn shl_assign(&mut self, shift: T)
fn shl_assign(&mut self, shift: T)
<<= operation. Read moresource§impl<T> ShrAssign<T> for U64
impl<T> ShrAssign<T> for U64
source§fn shr_assign(&mut self, shift: T)
fn shr_assign(&mut self, shift: T)
>>= operation. Read moresource§impl SubAssign for U64
impl SubAssign for U64
source§fn sub_assign(&mut self, other: U64)
fn sub_assign(&mut self, other: U64)
-= operation. Read moreimpl Copy for U64
impl Eq for U64
impl StructuralPartialEq for U64
Auto Trait Implementations§
impl Freeze for U64
impl RefUnwindSafe for U64
impl Send for U64
impl Sync for U64
impl Unpin for U64
impl UnwindSafe for U64
Blanket Implementations§
source§impl<T, U> AsByteSlice<T> for U
impl<T, U> AsByteSlice<T> for U
fn as_byte_slice(&self) -> &[u8] ⓘ
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§default unsafe fn clone_to_uninit(&self, dst: *mut T)
default unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit)source§impl<T> CloneToUninit for Twhere
T: Copy,
impl<T> CloneToUninit for Twhere
T: Copy,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit)