diff options
| author | Alex Crichton <alex@alexcrichton.com> | 2015-01-15 14:11:40 -0800 |
|---|---|---|
| committer | Alex Crichton <alex@alexcrichton.com> | 2015-01-15 14:11:40 -0800 |
| commit | 573c1f807a8ec21b2d314073768f81ef65dc9ec0 (patch) | |
| tree | c3fc84b957bb9f5133d53048c735c3da539474a3 /src/libstd | |
| parent | 56cf6ba61f82d00ad67984bbb17a18f819e75169 (diff) | |
| parent | 6a7f0a99d8005187736c3c26c5cc2d538a42590f (diff) | |
| download | rust-573c1f807a8ec21b2d314073768f81ef65dc9ec0.tar.gz rust-573c1f807a8ec21b2d314073768f81ef65dc9ec0.zip | |
rollup merge of #21059: steveklabnik/gh16072
Fixes #16072 r? @huonw
Diffstat (limited to 'src/libstd')
| -rw-r--r-- | src/libstd/rand/mod.rs | 27 |
1 files changed, 26 insertions, 1 deletions
diff --git a/src/libstd/rand/mod.rs b/src/libstd/rand/mod.rs index 60d490982db..8130a6c82ec 100644 --- a/src/libstd/rand/mod.rs +++ b/src/libstd/rand/mod.rs @@ -374,9 +374,13 @@ impl Rng for ThreadRng { /// `random()` can generate various types of random things, and so may require /// type hinting to generate the specific type you want. /// +/// This function uses the thread local random number generator. This means +/// that if you're calling `random()` in a loop, caching the generator can +/// increase performance. An example is shown below. +/// /// # Examples /// -/// ```rust +/// ``` /// use std::rand; /// /// let x = rand::random(); @@ -389,6 +393,27 @@ impl Rng for ThreadRng { /// println!("Better lucky than good!"); /// } /// ``` +/// +/// Caching the thread local random number generator: +/// +/// ``` +/// use std::rand; +/// use std::rand::Rng; +/// +/// let mut v = vec![1, 2, 3]; +/// +/// for x in v.iter_mut() { +/// *x = rand::random() +/// } +/// +/// // would be faster as +/// +/// let mut rng = rand::thread_rng(); +/// +/// for x in v.iter_mut() { +/// *x = rng.gen(); +/// } +/// ``` #[inline] pub fn random<T: Rand>() -> T { thread_rng().gen() |
