Expand description
A simple and fast random number generator.
The implementation uses Wyrand, a simple and fast generator but not cryptographically secure.
Examples
Flip a coin:
if fastrand::bool() {
println!("heads");
} else {
println!("tails");
}Generate a random i32:
let num = fastrand::i32(..);Choose a random element in an array:
let v = vec![1, 2, 3, 4, 5];
let i = fastrand::usize(..v.len());
let elem = v[i];Shuffle an array:
let mut v = vec![1, 2, 3, 4, 5];
fastrand::shuffle(&mut v);Generate a random Vec or String:
use std::iter::repeat_with;
let v: Vec<i32> = repeat_with(|| fastrand::i32(..)).take(10).collect();
let s: String = repeat_with(fastrand::alphanumeric).take(10).collect();To get reproducible results on every run, initialize the generator with a seed:
// Pick an arbitrary number as seed.
fastrand::seed(7);
// Now this prints the same number on every run:
println!("{}", fastrand::u32(..));To be more efficient, create a new Rng instance instead of using the thread-local
generator:
use std::iter::repeat_with;
let rng = fastrand::Rng::new();
let mut bytes: Vec<u8> = repeat_with(|| rng.u8(..)).take(10_000).collect();Structs
- A random number generator.
Functions
- Generates a random
charin ranges a-z and A-Z. - Generates a random
charin ranges a-z, A-Z and 0-9. - Generates a random
bool. - Generates a random
charin the given range. - Generates a random digit in the given
base. - Generates a random
f32in range0..1. - Generates a random
f64in range0..1. - Gives back current seed that is being held by the thread-local generator.
- Generates a random
i8in the given range. - Generates a random
i16in the given range. - Generates a random
i32in the given range. - Generates a random
i64in the given range. - Generates a random
i128in the given range. - Generates a random
isizein the given range. - Generates a random
charin range a-z. - Initializes the thread-local generator with the given seed.
- Shuffles a slice randomly.
- Generates a random
u8in the given range. - Generates a random
u16in the given range. - Generates a random
u32in the given range. - Generates a random
u64in the given range. - Generates a random
u128in the given range. - Generates a random
charin range A-Z. - Generates a random
usizein the given range.