Sign in

Build 10x products in minutes by chatting with AI - beyond just a prototype.
When working with Swift, you often come across computed and stored properties. Understanding how these properties work is crucial to becoming a proficient Swift developer. Swift's computed property feature allows developers to create a property whose value is calculated dynamically, rather than stored directly in memory like a stored property. This distinction is key for developing efficient, flexible code in the Swift programming language.
In this blog, we’ll dive deep into computed properties, how they differ from stored properties, and how you can use them effectively in Swift. By the end, you'll clearly understand Swift computed property, how to write one, and where it fits in your development workflow.
In simple terms, a computed property doesn’t store a value. Instead, it calculates a value whenever it is accessed. A computed property derives its value based on other properties or values within a class or structure. This makes computed properties especially useful when you want a property that updates its value dynamically based on other property changes.
A computed property in Swift typically consists of a getter, and optionally, a setter if the property is mutable. Here’s how a basic computed property looks:
1struct Rectangle { 2 var width: Double 3 var height: Double 4 5 var area: Double { 6 // Computed property 7 get { 8 return width * height 9 } 10 } 11}
In this example, the area is a computed property. It does not store a value directly but calculates it based on the width and height of the rectangle whenever it's accessed.
The main difference between a stored property and a computed property is that a stored property directly holds data in memory, while a computed property calculates its value dynamically. A stored property can have a default value or a user-defined value that is saved and retained. For example:
1struct Circle { 2 var radius: Double = 5.0 // Stored property 3}
Here, radius is a stored property with a default value of 5.0.
While stored properties hold the value directly, computed properties calculate their values indirectly based on other properties. For instance, in the Rectangle example, area is not stored but computed dynamically.
In Swift, a computed property can be made read-only by providing just a getter without a setter. These read-only computed properties are useful when you want to expose a dynamically calculated value but prevent modification.
Here’s an example of a read-only computed property:
1struct Rectangle { 2 var width: Double 3 var height: Double 4 5 // Read-only computed property 6 var perimeter: Double { 7 return 2 * (width + height) 8 } 9}
In this case, perimeter is a read-only computed property since it only has a getter. You cannot set a new value for it directly.
You can also create a computed property with a setter. This allows you to set a new value, and the setter can manipulate other properties or trigger some internal logic. Here’s an example where the setter updates multiple properties indirectly:
1struct Square { 2 var sideLength: Double = 0.0 3 4 var area: Double { 5 get { 6 return sideLength * sideLength 7 } 8 set(newArea) { 9 sideLength = sqrt(newArea) 10 } 11 } 12}
In this case, setting the area (a computed property) indirectly updates the sideLength. This example illustrates how computed properties not only retrieve values but can also modify other properties and values.
It’s important to note that property observers such as willSet and didSet are only available for stored properties, not computed ones. That said, you can still indirectly observe values in a computed property using custom setters.
Computed properties are a powerful feature of Swift that let you keep your data in sync without manually updating multiple properties. By calculating values indirectly, you ensure consistency between properties.
Here are a few common use cases where computed properties shine:
Dynamic Calculations: When you need a property that changes based on other properties, such as calculating dimensions, areas, or speeds.
Simplified Code: Using computed properties avoids unnecessary stored values, reducing code complexity and potential bugs.
Efficient Data Management: Computed properties are especially useful when you have data that are derived from other values but does not need to be stored directly.
Let’s take a look at a more complex example that showcases both a getter and setter in a computed property:
1struct File { 2 var filename: String 3 var extensionType: String 4 5 // Computed property combining two stored properties 6 var fullFilename: String { 7 get { 8 return "\(filename).\(extensionType)" 9 } 10 set(newFullFilename) { 11 let parts = newFullFilename.split(separator: ".") 12 if parts.count == 2 { 13 filename = String(parts[0]) 14 extensionType = String(parts[1]) 15 } 16 } 17 } 18}
In this case, fullFilename is a computed property that derives its value from two stored properties: filename and extensionType. This computed property returns the full filename when accessed, and optionally a setter allows updating both the filename and extensionType.
• Flexibility: Computed properties offer flexibility by letting you calculate values on the fly.
• Efficiency: Since computed properties calculate values dynamically, they prevent redundant storage of data.
• Code Maintenance: Computed properties centralize logic and calculations, making code easier to maintain.
• Real-time Updates: Since a computed property is recalculated every time it’s accessed, the value always reflects the latest state of related properties.
In this article, we explored the concept of a Swift computed property, which calculates its value dynamically rather than storing it directly, unlike stored properties. We covered how computed properties can have a getter and optionally a setter, making them useful for deriving values based on other properties.
Additionally, we highlighted the distinction between read-only computed properties and those with setters. By mastering both stored and computed properties, you can write more efficient, maintainable Swift code. Understanding the versatility of a Swift computed property is key to optimizing your development workflow.