Mastering Operators in Swift
Operators are a fundamental part of any programming language, and Swift is no exception. They are represented as symbols and have various associated properties. Understanding operators is crucial to mastering Swift.
What is an Operator in Swift?
In Swift, an operator is a symbol used to perform a logical, computational, or assignment operation. For example, = is used to assign, and + is used to add.
Types of Operators in Swift
There are three types of operators in Swift:
- Unary operators: work on only one operand (e.g., !,-)
- Binary operators: work on two operands (e.g., +,-,*)
- Ternary operator: works on three operands (e.g., ?:)
Operator Notation
Notation defines the position of the operator when used with operands. There are three types of notation:
- Infix: operator is used between operands (e.g., a + b)
- Prefix: operator is used before an operand (e.g., !a)
- Postfix: operator is used after an operand (e.g., a++)
Operator Precedence and Associativity
When working with multiple operators in an expression, Swift needs to know which operator to execute first. This is determined by operator precedence and associativity.
Precedence: determines the order in which operators are executed. Higher precedence operators are executed first.
Associativity: determines the direction in which an expression is evaluated when there are multiple operators with the same precedence. Left-associative operators are evaluated from left to right, while right-associative operators are evaluated from right to left.
Common Operators in Swift
Some common operators in Swift include:
- Assignment operator: =
- Arithmetic operators: +,-,*,/,%
- Logical operators: !,&&,||
- Comparison operators: >,<,==,>=,<=,!=
- Ternary operator: ?:
Creating Custom Operators in Swift
Custom operators can be created to define new operations or override existing ones. There are three types of custom operators:
- Global operator: defined at the global scope
- Operator for a class or struct: defined as a static function within a class or struct
- Compound operator: combines multiple operators into a single operator
Defining a Custom Operator
A custom operator is defined using the operator keyword followed by the operator symbol. The operator function is then defined using the func keyword.
operator prefix ↑ {}
func ↑(value: Double) -> Double {
    return value * value
}Specifying the Notation of a Custom Operator
The notation of a custom operator can be specified using the infix, prefix, or postfix keyword.
infix operator ↑: MultiplicationPrecedence
func ↑(lhs: Double, rhs: Double) -> Double {
    return lhs * rhs
}Setting Precedence of Custom Operators
The precedence of a custom operator can be set using the precedence keyword.
precedencegroup MultiplicationPrecedence {
    associativity: left
    higherThan: AdditionPrecedence
    lowerThan: ExponentiationPrecedence
}
infix operator ↑: MultiplicationPrecedence
func ↑(lhs: Double, rhs: Double) -> Double {
    return lhs * rhs
}