Sometimes functions fail because they have bad input, or because something went wrong internally. Swift lets us throw errors from functions by marking them as throws
before their return type, then using the throw
keyword when something goes wrong.
First we need to define an enum
that describes the errors we can throw. These must always be based on Swift’s existing Error
type. We’re going to write a function that checks whether a password is good, so we’ll throw an error if the user tries an obvious password:
enum PasswordError: Error {
case obvious
}
Now we’ll write a checkPassword()
function that will throw that error if something goes wrong. This means using the throws
keyword before the function’s return value, then using throw PasswordError.obvious
if their password is “password”.
Here’s that in Swift:
func checkPassword(_ password: String) throws -> Bool {
if password == "password" {
throw PasswordError.obvious
}
return true
}
GO FURTHER, FASTER Unleash your full potential as a Swift developer with the all-new Swift Career Accelerator: the most comprehensive, career-transforming learning resource ever created for iOS development. Whether you’re just starting out, looking to land your first job, or aiming to become a lead developer, this program offers everything you need to level up – from mastering Swift’s latest features to conquering interview questions and building robust portfolios.
Sponsor Hacking with Swift and reach the world's largest Swift community!
Link copied to your pasteboard.