Swift开发笔记3.Swift中setter和getter的基本用法

简介: Swift中有存储属性和计算属性两种。其中在计算属性中可以实现setter和getter方法,我们在playground中定义两个结构体:struct Point { var x = 0.0, y = 0.0}struct Size { var width = 0.0, hight = 0.0}假设这两个结构体要实现一个画图的功能。

Swift中有存储属性和计算属性两种。其中在计算属性中可以实现setter和getter方法,我们在playground中定义两个结构体:

struct Point {
    var x = 0.0, y = 0.0
}

struct Size {
    var width = 0.0, hight = 0.0
}


假设这两个结构体要实现一个画图的功能。point是起点,size是尺寸。可以看出point中有两个坐标点,size中描述了宽和高。像x、y这样存值的属性就是存储属性。然后我们创建一个Rect结构体,表示一个区域,注意结构体本身也是对象。Rect中创建了两个实体,origin是Point类型,标示区域的原点,size是Size类型,标示区域的尺寸。

struct Rect {
    var origin = Point()
    var size = Size()
}

Swift中提供了延迟加载的功能,可以像下面这样定义Rect的属性:

 lazy  var size = Size()

使用延迟加载就表示当我们加载Rect对象的时候可能暂时用不到size对象,那么就在需要加载size的时候再加载。

现在我在Rect中要求区域的中心点,中心点坐标的值依赖于前面的两个属性origin和size,我们只有知道了原点和尺寸才能通过计算得到center的值。我们首先用方法来实现center的计算,getCenter方法返回的是中心点坐标的元组。

struct Rect {
    var origin = Point()
    var size = Size()
    func getCenter() -> (Double,Double){
        let x = origin.x + (size.width / 2)
        let y = origin.y + (size.hight / 2)
        return (x,y)
    }
}


测试一下:

var rect = Rect(origin: Point(x: 100, y: 100), size: Size(width: 200, hight: 100))
var (x, y) = rect.getCenter()
println("\(x) , \(y)")


playground显示:


如果没有存储属性,那么我们是用以上的方法来实现中心点的求值的。现在引入存储属性,命名为center,center标示中心点坐标,它的值依赖于origin和size的值,center就是一个计算属性,代码如下:

 var center : Point {
        get {
            let x = origin.x + (size.width / 2)
            let y = origin.y + (size.hight / 2)
            return Point(x:x, y:y)
        }
    }

然后调用它:

var p2 = rect.center
println("\(p2.x),\(p2.y)")

可以看到运行结果是相同的,我们在调用的时候看起来像是调用了rect的属性center,实际是调用了cnter中的get方法.这个get方法就相当于一个getter,现在再来写一个set方法,

set方法需要传值,命名为newCenter。如果我们得到了一个新的中心点的值,那么在尺寸不变的情况下原点坐标可以被重新设置。这就需要一个set方法来实现,代码如下:

  set(newCenter) {
            origin.x = newCenter.x - (size.width / 2)
            origin.y = newCenter.y - (size.hight / 2)
        
        }

测试一下:

var p3 = Point(x: 300, y: 200)
rect.center = p3
println("\(rect.origin.x), \(rect.origin.y)")

结果如图:



使用get和set更加方便,代码可读性更高


目录
相关文章
|
3月前
|
Unix 调度 Swift
苹果iOS新手开发之Swift 中获取时间戳有哪些方式?
在Swift中获取时间戳有四种常见方式:1) 使用`Date`对象获取秒级或毫秒级时间戳;2) 通过`CFAbsoluteTimeGetCurrent`获取Core Foundation的秒数,需转换为Unix时间戳;3) 使用`DispatchTime.now()`获取纳秒级精度的调度时间点;4) `ProcessInfo`提供设备启动后的秒数,不表示绝对时间。不同方法适用于不同的精度和场景需求。
88 3
|
2天前
|
安全 Swift iOS开发
探索iOS开发中的Swift语言之美
在数字时代的浪潮中,移动应用已成为日常生活的延伸。本文将深入探讨iOS平台上的Swift编程语言,揭示其背后的设计哲学、语法特性以及如何利用Swift进行高效开发。我们将通过实际代码示例,展示Swift语言的强大功能和优雅简洁的编程风格,引导读者理解并运用Swift解决实际问题。
|
21天前
|
安全 Swift iOS开发
探索iOS开发之旅:Swift语言的魅力与挑战
【9月更文挑战第21天】在这篇文章中,我们将一起潜入iOS开发的海洋,探索Swift这门现代编程语言的独特之处。从简洁的语法到强大的功能,Swift旨在让开发者能够以更高效、更安全的方式构建应用程序。通过实际代码示例,我们会深入了解Swift如何简化复杂任务,并讨论它面临的挑战和未来的发展方向。无论你是初学者还是有经验的开发者,这篇文章都将为你提供新的视角和知识。
35 4
|
1月前
|
安全 编译器 Swift
探索iOS开发之旅:Swift编程语言的魅力与挑战
【9月更文挑战第5天】在iOS应用开发的广阔天地中,Swift作为苹果官方推荐的编程语言,以其简洁、高效和安全的特点,成为了开发者的新宠。本文将带领你领略Swift语言的独特魅力,同时探讨在实际开发过程中可能遇到的挑战,以及如何克服这些挑战,成为一名优秀的iOS开发者。
|
1月前
|
设计模式 前端开发 Swift
探索iOS开发:Swift与Objective-C的较量
在这篇文章中,我们将深入探讨iOS开发的两大编程语言——Swift与Objective-C。我们将分析这两种语言的特性、优势和局限性,并讨论它们在现代iOS开发中的应用。无论你是初学者还是有经验的开发者,这篇文章都将为你提供有价值的见解和建议。
43 3
|
2月前
|
存储 编译器 Swift
Swift笔记:Swift中的扩展语法
Swift笔记:Swift中的扩展语法
67 1
|
2月前
|
移动开发 安全 Swift
探索iOS开发:从零开始的Swift之旅
【8月更文挑战第31天】本文将带你开启一段Swift编程语言的奇幻旅程,通过简单易懂的方式介绍Swift的基本概念和编程实践。我们将一起构建一个简单的iOS应用,体验从代码到界面的转变。无论你是编程新手还是希望扩展技能的开发者,这篇文章都会为你提供宝贵的知识和启发。
|
2月前
|
API Swift C语言
探索iOS开发:Swift中的异步编程与GCD应用
【8月更文挑战第4天】在iOS开发的海洋中,掌握Swift语言的航向是至关重要的。本文将引领你深入理解Swift中的异步编程概念,并借助Grand Central Dispatch(GCD)这一强大的工具,来简化并发编程的复杂性。我们将通过实际代码示例,展现如何在iOS应用中高效地管理后台任务和提升用户界面的响应性。
57 3
|
3月前
|
Swift iOS开发 Kotlin
苹果iOS新手开发之Swift中实现类似Kotlin的作用域函数
Swift可通过扩展实现类似Kotlin作用域函数效果。如自定义`let`, `run`, `with`, `apply`, `also`,增强代码可读性和简洁性。虽无直接内置支持,但利用Swift特性可达成相似功能。
52 7
|
3月前
|
调度 Swift Android开发
苹果iOS新手开发之Swift中的并发任务和消息机制
Swift的消息机制类似Android的Handler,实现任务调度有三种方式: 1. **Grand Central Dispatch (GCD)**:使用`DispatchQueue`在主线程或后台线程执行任务。 2. **OperationQueue**:提供高级接口管理`Operation`对象。 3. **RunLoop**:处理事件如输入源、计时器,类似Android的`Looper`和`Handler`。 **示例**: - GCD:在不同线程执行代码块。 - OperationQueue:创建操作并执行。 - RunLoop:用Timer添加到RunLoop中。
84 2