Operators are unique characters or phrases that Swift uses to manipulate and validate values. Swift was specifically designed to enhance the operators from several programming languages to create more capability with less code for the programmer.

Assignment Operator

The assignment operator = in Swift is the same as in most other languages and serves the same purpose. It is used to initializae or reassign a variable to some value. In Swift, unlike some other high level programming languages like C or Java, the assignment operator does not return any values.

var a = 5
// When we reference variable 'a', it returns the value int: 5.
let z = (a = 6)
// Compile warning that 'b' is of type '()' "
// Output: '()'

Here, the z = (a=6) assignment leaves z to equal () once the a=6 is evaluated.

Arithmetic Operators

Swift contains the following operators that match their similar expressions in common math:

  • + for addition
  • - for subtraction
  • * for multiplication
  • / for division
  • % for modulus or remainder division

These work as you would expect for all mathematical operations, however the + operator can also be used to concatenate two strings together such as "Operators" + " in Swift" = "Operators in Swift".

Comparison Operators

These operators are used to return Bool values for use in conditional statements. These control logic flow in loops or if statements for example. The basic comparison operators are below:

  • == equal to
  • != not equal to
  • > greater than
  • >= greater than or equal to
  • < less than
  • <= less than or equal to

The following code snippet shows a use cases of comparison operators in a while loop that will :

var countUp = 0
var countDown = 10
while countUp < countDown {
countUp = countUp + 1
countDown = countDown - 1

Logical Operators

Logical Operators are used to evaluate or modify the value of Beolean values and are especially useful in control flow logic, in Swift there are three operators:

  • ! Logical NOT
  • && Logical AND
  • || Logical OR

Logical NOT(!) operator appears directly before a Boolean value with no spaces. This operator inverts the value of the Boolean so that true becomes false and vice versa.

var earthIsFlat = false
if !earthIsFlat {
print("All our physics doesn't work!")

Logical AND (&&) and logical OR (||) operators evalute two Booleans or Boolean expressions. In an AND evaluation, both expressions must result in true, resulting in the overall AND expression becoming true. In an OR evaluation only one expression must be true for the result of OR to be true. In both cases, if the left side of the expression evaluates to a value that the compiler can determine a value for the operator, the right side will not be evaluated at all.

var iAmTrue = true
var iAmFalse = false
if (iAmTrue && iAmFalse) {
// Both sides are checked because the first value is true and the compiler needs to check right side' value
print("Both values are 'true' and the AND operator returned 'true'.")
} else if (iAmTrue || iAmFalse) {
// Only the left side is evaluated, as soon as the compiler sees a 'true', it can reason that the OR requirements are met and will enter the 'else if' body
print("At least one value was 'true' and the OR operator returned 'true'.")
} else {
print("Neither value is 'true'.")

Range Operators

Range operators provide quick and convenient ways of creating various ranges or iterating over elements in an object. The three primary types are Closed ( a...z ), Half-Open (a..<z), and One-Sided (a...), each providing different limits on the range. Swift does not allow for the creation on decrementing ranges, therefore the value of the first variable must not be greater than the value of the second.

The Closed Range operator (a...z) creates a range that begins at a and continues to and includes, z. The most common use case for Closed Range Operators is in for-in loops.

let userAge = 32
for year in 2...userAge {
print("You turned \(year) years old!")

This should output:

You turned 2 years old!
You turned 3 years old!
... all the way to and including
You turned 32 years old!

Half-Open range operators(a..<z) create a range beginning at a and continue to z but not including z. They are commonly used when working with Arrays or other zero-indexed lists.

let picnic = ["Ceasar Salad", "Turkey Sandwich", "Cookie", "Juice Box"]
for i in 0..<picnic.count {
print("Item #\(i+1) in the picnic basket is a \(picnic[i]).")

This should output:

Item 1 in the picnic basket is a Ceasar Salad.
Item 2 in the picnic basket is a Turkey Sandwich.
Item 3 in the picnic basket is a Cookie.
Item 4 in the picnic basket is a Juice Box.

The One-Sided range operator defines a range that will continue as far in one direction as possible. We can use this range to iterate from or to specific ranges inside of other fixed length entities.

for food in picnic[...2] {
// Ceasar Salad
// Turkey Sandwich
// Cookie
for food in picnic[2...] {
// Cookie
// Juice Box
for food in picnic[..<3] {
// Ceasar Salad
// Turkey Sandwich
// Cookie
let infiniteRange = 0... // 0 to infinity
for i in infiniteRange {
// creates an infinite loop, always take note of what
// "stops" your open-ended ranges

Nil-Coalescing Operator

The nil-coalescing operator (a ?? z) unwraps an optional with the value of a unless a is nil, then it will return the value of z. a always has to be an optional type and z has to match the type that’s stored in a.

let defaultPrice = 1.99
var getItemPrice: Double?
let priceToChargeCustomer = getItemPrice ?? defaultPrice

Since getItemPrice isn’t assigned a value it defaults to ‘nil’. The price to charge the customer is either a price we get from an item or the default price. In this case, priceToChargeCustomer = 1.99

Ternary Conditional Operator

The ternary conditional operator is shorthand for a simple if-else statement. It follows the syntax statementToTest ? doThisAndReturnIfTrue : doThisAndReturnIfFalse which in terms of the if-else statement can be read as:

  • if the statement is true, evaluate and return the value of the left side of the ternary
  • if it’s false, evaluate and return the value of the right side.
let exoticBirdBingo = ["ostrich", "falcon", "peacock", "flamingo", "gold and blue macaw"]
let birdsSeen = ["flamingo", "pigeon", "blue jay", "peacock"]
for bird in birdsSeen {
print(exoticBirdBingo.contains(bird) ? "Cross \(bird) off your bingo card!" : "A \(bird) is just a normal bird.")

This would output:

Cross flamingo off your bingo card!
A pigeon just a normal bird.
A blue jay is just a normal bird.
Cross peacock off your bingo card!
Edit this page on GitHub


Interested in helping build Docs? Read the Contribution Guide or share your feedback.

Learn Swift on Codecademy

Edit this page on GitHub