A type that provides uniformly distributed random data.
- Xcode 10.0+Beta
- Swift Standard Library
When you call methods that use random data, such as creating new random values or shuffling a collection, you can pass a
Random type to be used as the source for randomness. When you don’t pass a generator, the default
Random type is used.
When providing new APIs that use randomness, provide a version that accepts a generator conforming to the
Random protocol as well as a version that uses the default generator. For example, this
Weekday enumeration provides static methods that return a random day of the week:
Conforming to the RandomNumberGenerator Protocol
Random type can have different characteristics than the default
Random type. For example, a seedable generator can be used to generate the same sequence of random values for testing purposes.
To make a custom type conform to the
Random protocol, implement the required
next() method. Each call to
next() must produce a uniform and independent random value.
Types that conform to
Random should specifically document the thread safety and quality of the generator.