NEW! Master Swift design patterns with my latest book! >>

< Previous: Generating random numbers without GameplayKit   Next: Choosing a random number source: GKARC4RandomSource and other GameplayKit options >

Generating random numbers with GameplayKit: GKRandomSource

Let's look at the most basic way of generating random numbers using GameplayKit, which is the GKRandomSource class and its sharedRandom() method. Of course, this means adding an import for GameplayKit into the playground, so please do that now.

A random source is a provider of an unfiltered stream of random numbers as you need them. As you'll see soon, GameplayKit has various options for your stream, but for now we're going to look at the simplest one: sharedRandom().

Using sharedRandom() for a random number source returns the systems built-in random source that's used for a variety of other tasks, which means you can be pretty sure it's in a truly random state by the time it gets to you. It does, however, mean that it's useless for synchronizing network games, because everyone's device is in a different state.

To produce a truly random number you'd use the nextInt() method like this:

print(GKRandomSource.sharedRandom().nextInt())

That produces a number between -2,147,483,648 and 2,147,483,647 – yes, that's a negative number, which means it's not a drop-in replacement for arc4random(). Plus, even with GameplayKit's great new logic, Apple includes a warning that it's not guaranteed to be random for very specific situations, so for both these reasons it's not likely you'll want to use nextInt() much.

As an alternative, try using the nextInt(upperBound:) method, which works identically to arc4random():

print(GKRandomSource.sharedRandom().nextInt(upperBound: 6))

That will return a random number from 0 to 5 using the system's built-in random number generator.

As well as nextInt() and nextInt(upperBound:) are nextBool() for generating a random true/false value and nextUniform() for generating a random floating-point number between 0 and 1. Both of these are implemented using nextInt(upperBound:) so they output properly random numbers.

Help support Hacking with Swift

This site is funded by Hacking with Swift supporters who buy my e-books. If you can, please support my work – it comes packed with bonus material!

< Previous: Generating random numbers without GameplayKit   Next: Choosing a random number source: GKARC4RandomSource and other GameplayKit options >
MASTER SWIFT NOW
Buy Practical iOS 12 Buy Pro Swift Buy Swift Design Patterns Buy Practical iOS 11 Buy Swift Coding Challenges Buy Server-Side Swift (Vapor Edition) Buy Server-Side Swift (Kitura Edition) Buy Hacking with macOS Buy Advanced iOS Volume One Buy Hacking with watchOS Buy Hacking with tvOS Buy Hacking with Swift Buy Dive Into SpriteKit Buy Swift in Sixty Seconds Buy Objective-C for Swift Developers Buy Beyond Code

Was this page useful? Let me know!

Click here to visit the Hacking with Swift store >>