[−][src]Struct rand_core::block::BlockRng64
A wrapper type implementing RngCore
for some type implementing
[BlockRngCore
] with u64
array buffer; i.e. this can be used to implement
a full RNG from just a generate
function.
This is similar to [BlockRng
], but specialized for algorithms that operate
on u64
values.
No whole generated u64
values are thrown away and all values are consumed
in-order. next_u64
simply takes the next available u64
value.
next_u32
is however a bit special: half of a u64
is consumed, leaving
the other half in the buffer. If the next function called is next_u32
then the other half is then consumed, however both next_u64
and
fill_bytes
discard the rest of any half-consumed u64
s when called.
fill_bytes
and try_fill_bytes
consume a whole number of u64
values. If the requested length is not a multiple of 8, some bytes will be
discarded.
Fields
core: R
The core part of the RNG, implementing the generate
function.
Methods
impl<R> BlockRng64<R> where
R: BlockRngCore,
[src]
R: BlockRngCore,
pub fn new(core: R) -> BlockRng64<R>
[src]
Create a new BlockRng
from an existing RNG implementing
BlockRngCore
. Results will be generated on first use.
pub fn index(&self) -> usize
[src]
Get the index into the result buffer.
If this is equal to or larger than the size of the result buffer then
the buffer is "empty" and generate()
must be called to produce new
results.
pub fn reset(&mut self)
[src]
Reset the number of available results. This will force a new set of results to be generated on next use.
pub fn generate_and_set(&mut self, index: usize)
[src]
Generate a new set of results immediately, setting the index to the given value.
Trait Implementations
impl<R> Debug for BlockRng64<R> where
R: BlockRngCore + Debug,
[src]
R: BlockRngCore + Debug,
impl<R> Clone for BlockRng64<R> where
R: BlockRngCore + Clone + ?Sized,
<R as BlockRngCore>::Results: Clone,
[src]
R: BlockRngCore + Clone + ?Sized,
<R as BlockRngCore>::Results: Clone,
fn clone(&self) -> BlockRng64<R>
[src]
default fn clone_from(&mut self, source: &Self)
1.0.0[src]
Performs copy-assignment from source
. Read more
impl<R> SeedableRng for BlockRng64<R> where
R: BlockRngCore + SeedableRng,
[src]
R: BlockRngCore + SeedableRng,
type Seed = <R as SeedableRng>::Seed
Seed type, which is restricted to types mutably-dereferencable as u8
arrays (we recommend [u8; N]
for some N
). Read more
fn from_seed(seed: <BlockRng64<R> as SeedableRng>::Seed) -> BlockRng64<R>
[src]
fn seed_from_u64(seed: u64) -> BlockRng64<R>
[src]
fn from_rng<S>(rng: S) -> Result<BlockRng64<R>, Error> where
S: RngCore,
[src]
S: RngCore,
impl<R> RngCore for BlockRng64<R> where
R: BlockRngCore<Item = u64>,
<R as BlockRngCore>::Results: AsRef<[u64]>,
<R as BlockRngCore>::Results: AsMut<[u64]>,
[src]
R: BlockRngCore<Item = u64>,
<R as BlockRngCore>::Results: AsRef<[u64]>,
<R as BlockRngCore>::Results: AsMut<[u64]>,
Auto Trait Implementations
impl<R: ?Sized> Send for BlockRng64<R> where
R: Send,
<R as BlockRngCore>::Results: Send,
R: Send,
<R as BlockRngCore>::Results: Send,
impl<R: ?Sized> Sync for BlockRng64<R> where
R: Sync,
<R as BlockRngCore>::Results: Sync,
R: Sync,
<R as BlockRngCore>::Results: Sync,
Blanket Implementations
impl<T> From for T
[src]
impl<T, U> TryFrom for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<T, U> Into for T where
U: From<T>,
[src]
U: From<T>,
impl<T> Borrow for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut for T where
T: ?Sized,
[src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,