#[repr(C)]pub struct U256(pub [u64; 4]);Expand description
Little-endian large integer type 256-bit unsigned integer.
Tuple Fields§
§0: [u64; 4]Implementations§
Source§impl U256
impl U256
Sourcepub fn from_str_radix(txt: &str, radix: u32) -> Result<U256, FromStrRadixErr>
pub fn from_str_radix(txt: &str, radix: u32) -> Result<U256, 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<U256, FromDecStrErr>
pub fn from_dec_str(value: &str) -> Result<U256, 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 const fn byte(&self, index: usize) -> u8
pub const fn byte(&self, index: usize) -> u8
Return specific byte. Byte 0 is the least significant value (ie~ little endian).
§Panics
Panics if index exceeds the byte width of the number.
Sourcepub fn to_big_endian(&self) -> [u8; 32]
pub fn to_big_endian(&self) -> [u8; 32]
Convert to big-endian bytes.
Sourcepub fn write_as_big_endian(&self, bytes: &mut [u8])
pub fn write_as_big_endian(&self, bytes: &mut [u8])
Write to the slice in big-endian format.
Sourcepub fn to_little_endian(&self) -> [u8; 32]
pub fn to_little_endian(&self) -> [u8; 32]
Convert to little-endian bytes.
pub fn write_as_little_endian(&self, bytes: &mut [u8])
Sourcepub fn integer_sqrt(&self) -> U256
pub fn integer_sqrt(&self) -> U256
Compute the highest n such that n * n <= self.
Sourcepub fn pow(self, expon: U256) -> U256
pub fn pow(self, expon: U256) -> U256
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: U256) -> (U256, bool)
pub fn overflowing_pow(self, expon: U256) -> (U256, bool)
Fast exponentiation by squaring. Returns result and overflow flag.
Sourcepub fn checked_pow(self, expon: U256) -> Option<U256>
pub fn checked_pow(self, expon: U256) -> Option<U256>
Checked exponentiation. Returns None if overflow occurred.
Sourcepub fn overflowing_add(self, other: U256) -> (U256, bool)
pub fn overflowing_add(self, other: U256) -> (U256, bool)
Addition which overflows and returns a flag if it does.
Sourcepub fn saturating_add(self, other: U256) -> U256
pub fn saturating_add(self, other: U256) -> U256
Addition which saturates at the maximum value (Self::MAX).
Sourcepub fn checked_add(self, other: U256) -> Option<U256>
pub fn checked_add(self, other: U256) -> Option<U256>
Checked addition. Returns None if overflow occurred.
Sourcepub fn overflowing_sub(self, other: U256) -> (U256, bool)
pub fn overflowing_sub(self, other: U256) -> (U256, bool)
Subtraction which underflows and returns a flag if it does.
Sourcepub fn saturating_sub(self, other: U256) -> U256
pub fn saturating_sub(self, other: U256) -> U256
Subtraction which saturates at zero.
Sourcepub fn checked_sub(self, other: U256) -> Option<U256>
pub fn checked_sub(self, other: U256) -> Option<U256>
Checked subtraction. Returns None if overflow occurred.
Sourcepub fn abs_diff(self, other: U256) -> U256
pub fn abs_diff(self, other: U256) -> U256
Computes the absolute difference between self and other.
Sourcepub fn overflowing_mul(self, other: U256) -> (U256, bool)
pub fn overflowing_mul(self, other: U256) -> (U256, bool)
Multiply with overflow, returning a flag if it does.
Sourcepub fn saturating_mul(self, other: U256) -> U256
pub fn saturating_mul(self, other: U256) -> U256
Multiplication which saturates at the maximum value..
Sourcepub fn checked_mul(self, other: U256) -> Option<U256>
pub fn checked_mul(self, other: U256) -> Option<U256>
Checked multiplication. Returns None if overflow occurred.
Sourcepub fn checked_div(self, other: U256) -> Option<U256>
pub fn checked_div(self, other: U256) -> Option<U256>
Checked division. Returns None if other == 0.
Sourcepub fn checked_rem(self, other: U256) -> Option<U256>
pub fn checked_rem(self, other: U256) -> Option<U256>
Checked modulus. Returns None if other == 0.
Sourcepub fn overflowing_neg(self) -> (U256, bool)
pub fn overflowing_neg(self) -> (U256, bool)
Negation with overflow.
Sourcepub fn checked_neg(self) -> Option<U256>
pub fn checked_neg(self) -> Option<U256>
Checked negation. Returns None unless self == 0.
Sourcepub fn from_big_endian(slice: &[u8]) -> U256
pub fn from_big_endian(slice: &[u8]) -> U256
Converts from big endian representation bytes in memory.
Sourcepub fn from_little_endian(slice: &[u8]) -> U256
pub fn from_little_endian(slice: &[u8]) -> U256
Converts from little endian representation bytes in memory.
Trait Implementations§
Source§impl AddAssign for U256
impl AddAssign for U256
Source§fn add_assign(&mut self, other: U256)
fn add_assign(&mut self, other: U256)
+= operation. Read moreSource§impl ArchiveWith<U256> for U256Wrapper
impl ArchiveWith<U256> for U256Wrapper
Source§type Archived = ArchivedU256Wrapper
type Archived = ArchivedU256Wrapper
Self with F.Source§type Resolver = U256WrapperResolver
type Resolver = U256WrapperResolver
Self with F.Source§impl BitAndAssign for U256
impl BitAndAssign for U256
Source§fn bitand_assign(&mut self, rhs: U256)
fn bitand_assign(&mut self, rhs: U256)
&= operation. Read moreSource§impl BitOrAssign for U256
impl BitOrAssign for U256
Source§fn bitor_assign(&mut self, rhs: U256)
fn bitor_assign(&mut self, rhs: U256)
|= operation. Read moreSource§impl BitXorAssign for U256
impl BitXorAssign for U256
Source§fn bitxor_assign(&mut self, rhs: U256)
fn bitxor_assign(&mut self, rhs: U256)
^= operation. Read moreimpl Copy for U256
Source§impl<'de> Deserialize<'de> for U256
impl<'de> Deserialize<'de> for U256
Source§fn deserialize<D>(
deserializer: D,
) -> Result<U256, <D as Deserializer<'de>>::Error>where
D: Deserializer<'de>,
fn deserialize<D>(
deserializer: D,
) -> Result<U256, <D as Deserializer<'de>>::Error>where
D: Deserializer<'de>,
Source§impl<__D: Fallible + ?Sized> DeserializeWith<<U256Wrapper as ArchiveWith<U256>>::Archived, U256, __D> for U256Wrapper
impl<__D: Fallible + ?Sized> DeserializeWith<<U256Wrapper as ArchiveWith<U256>>::Archived, U256, __D> for U256Wrapper
Source§fn deserialize_with(
field: &<U256Wrapper as ArchiveWith<U256>>::Archived,
deserializer: &mut __D,
) -> Result<U256, <__D as Fallible>::Error>
fn deserialize_with( field: &<U256Wrapper as ArchiveWith<U256>>::Archived, deserializer: &mut __D, ) -> Result<U256, <__D as Fallible>::Error>
F using the given deserializer.Source§impl<T> DivAssign<T> for U256
impl<T> DivAssign<T> for U256
Source§fn div_assign(&mut self, other: T)
fn div_assign(&mut self, other: T)
/= operation. Read moreimpl Eq for U256
Source§impl From<U256Wrapper> for U256
impl From<U256Wrapper> for U256
Source§fn from(value: U256Wrapper) -> Self
fn from(value: U256Wrapper) -> Self
Source§impl MulAssign for U256
impl MulAssign for U256
Source§fn mul_assign(&mut self, other: U256)
fn mul_assign(&mut self, other: U256)
*= operation. Read moreSource§impl MulAssign<i8> for U256
impl MulAssign<i8> for U256
Source§fn mul_assign(&mut self, other: i8)
fn mul_assign(&mut self, other: i8)
*= operation. Read moreSource§impl MulAssign<i16> for U256
impl MulAssign<i16> for U256
Source§fn mul_assign(&mut self, other: i16)
fn mul_assign(&mut self, other: i16)
*= operation. Read moreSource§impl MulAssign<i32> for U256
impl MulAssign<i32> for U256
Source§fn mul_assign(&mut self, other: i32)
fn mul_assign(&mut self, other: i32)
*= operation. Read moreSource§impl MulAssign<i64> for U256
impl MulAssign<i64> for U256
Source§fn mul_assign(&mut self, other: i64)
fn mul_assign(&mut self, other: i64)
*= operation. Read moreSource§impl MulAssign<isize> for U256
impl MulAssign<isize> for U256
Source§fn mul_assign(&mut self, other: isize)
fn mul_assign(&mut self, other: isize)
*= operation. Read moreSource§impl MulAssign<u8> for U256
impl MulAssign<u8> for U256
Source§fn mul_assign(&mut self, other: u8)
fn mul_assign(&mut self, other: u8)
*= operation. Read moreSource§impl MulAssign<u16> for U256
impl MulAssign<u16> for U256
Source§fn mul_assign(&mut self, other: u16)
fn mul_assign(&mut self, other: u16)
*= operation. Read moreSource§impl MulAssign<u32> for U256
impl MulAssign<u32> for U256
Source§fn mul_assign(&mut self, other: u32)
fn mul_assign(&mut self, other: u32)
*= operation. Read moreSource§impl MulAssign<u64> for U256
impl MulAssign<u64> for U256
Source§fn mul_assign(&mut self, other: u64)
fn mul_assign(&mut self, other: u64)
*= operation. Read moreSource§impl MulAssign<usize> for U256
impl MulAssign<usize> for U256
Source§fn mul_assign(&mut self, other: usize)
fn mul_assign(&mut self, other: usize)
*= operation. Read moreSource§impl Ord for U256
impl Ord for U256
1.21.0 (const: unstable) · Source§fn max(self, other: Self) -> Selfwhere
Self: Sized,
fn max(self, other: Self) -> Selfwhere
Self: Sized,
Source§impl PartialOrd for U256
impl PartialOrd for U256
Source§impl RLPDecode for U256
impl RLPDecode for U256
fn decode_unfinished(rlp: &[u8]) -> Result<(U256, &[u8]), RLPDecodeError>
fn decode(rlp: &[u8]) -> Result<Self, RLPDecodeError>
Source§impl<T> RemAssign<T> for U256
impl<T> RemAssign<T> for U256
Source§fn rem_assign(&mut self, other: T)
fn rem_assign(&mut self, other: T)
%= operation. Read moreSource§impl Serialize for U256
impl Serialize for U256
Source§fn serialize<S>(
&self,
serializer: S,
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>where
S: Serializer,
fn serialize<S>(
&self,
serializer: S,
) -> Result<<S as Serializer>::Ok, <S as Serializer>::Error>where
S: Serializer,
Source§impl<__S: Fallible + ?Sized> SerializeWith<U256, __S> for U256Wrapper
impl<__S: Fallible + ?Sized> SerializeWith<U256, __S> for U256Wrapper
Source§impl<T> ShlAssign<T> for U256
impl<T> ShlAssign<T> for U256
Source§fn shl_assign(&mut self, shift: T)
fn shl_assign(&mut self, shift: T)
<<= operation. Read moreSource§impl<T> ShrAssign<T> for U256
impl<T> ShrAssign<T> for U256
Source§fn shr_assign(&mut self, shift: T)
fn shr_assign(&mut self, shift: T)
>>= operation. Read moreimpl StructuralPartialEq for U256
Source§impl SubAssign for U256
impl SubAssign for U256
Source§fn sub_assign(&mut self, other: U256)
fn sub_assign(&mut self, other: U256)
-= operation. Read moreAuto Trait Implementations§
impl Freeze for U256
impl RefUnwindSafe for U256
impl Send for U256
impl Sync for U256
impl Unpin for U256
impl UnsafeUnpin for U256
impl UnwindSafe for U256
Blanket Implementations§
Source§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
Source§type ArchivedMetadata = ()
type ArchivedMetadata = ()
Source§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata,
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata
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§impl<Q, K> Comparable<K> for Q
impl<Q, K> Comparable<K> for Q
impl<T> DeserializeOwned for Twhere
T: for<'de> Deserialize<'de>,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key and return true if they are equal.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
impl<T, Rhs, Output> GroupOps<Rhs, Output> for T
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
Source§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Source§impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
impl<T, N1, N2> Niching<NichedOption<T, N1>> for N2
Source§unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
unsafe fn is_niched(niched: *const NichedOption<T, N1>) -> bool
Source§fn resolve_niched(out: Place<NichedOption<T, N1>>)
fn resolve_niched(out: Place<NichedOption<T, N1>>)
out indicating that a T is niched.