swift_020(Swift 的属性)

//***********swift学习之20--属性--***************************

// 属性比较属性,不需要介绍太多,只知道还可以定义属性观察器来监控属性值的变化,以此来触发一个自定义的操作。属性观察器可以添加到自己写的存储属性上,也可以添加到从父类继承的属性上。




// 延迟存储属性

// 延迟存储属性是指当第一次被调用的时候才会计算其初始值的属性。

// 在属性声明前使用 lazy 来标示一个延迟存储属性。


// 注意:

// 必须将延迟存储属性声明成变量(使用var关键字),因为属性的值在实例构造完成之前可能无法得到。而常量属性在构造过程完成之前必须要有初始值,因此无法声明成延迟属性。


// 延迟存储属性一般用于:

// a:延迟对象的创建。

// b:当属性的值依赖于其他未知类


// 实战:延迟存储属性


class Book {

    var name = "延迟存储属性"

}


class LazySemple {

    lazy var name = Book ()

}


var sampleObject = LazySemple()

print(sampleObject.name.name)



// 计算属性 主要练习setter getter方法


class sample {

    var no1 = 0.0, no2 = 0.0

    var length = 300.0, breadth = 150.0

    

    var middle: (Double, Double) {

        

        set(axis){

            no1 = axis.0 - (length / 2)

            no2 = axis.1 - (breadth / 2)

        }

        

        get{

            return (length / 2, breadth / 2)

        }

    }

}


var result = sample()

print(result.middle)

result.middle = (0.0, 10.0 // setter 方法


print(result.no1)

print(result.no2)



// 只读计算属性

// 只有 getter 没有 setter 的计算属性就是只读计算属性。

// 只读计算属性总是返回一个值,可以通过点(.)运算符访问,但不能设置新的值。


class film {

    var head = ""

    var duration = 0.0

    var metaInfo: [String:String] {

        return [

            "head": self.head,

            "duration":"\(self.duration)"

        ]

    }

}


var movie = film()

movie.head = "Swift 属性"

movie.duration = 3.09


print(movie.metaInfo["head"]!)

print(movie.metaInfo["duration"]!)


/*

 属性观察器

 属性观察器监控和响应属性值的变化,每次属性被设置值的时候都会调用属性观察器,甚至新的值和现在的值相同的时候也不例外。

 可以为除了延迟存储属性之外的其他存储属性添加属性观察器,也可以通过重载属性的方式为继承的属性(包括存储属性和计算属性)添加属性观察器。

 注意:

 不需要为无法重载的计算属性添加属性观察器,因为可以通过 setter 直接监控和响应值的变化。

 可以为属性添加如下的一个或全部观察器:

 willSet在设置新的值之前调用

 didSet在新的值被设置之后立即调用

 willSetdidSet观察器在属性初始化过程中不会被调用

 

 */


class Samplepgm {

    var counter: Int = 0{

        willSet(newTotal){

            print("计数器: \(newTotal)")

        }

        didSet{

            if counter > oldValue {

                print("新增数 \(counter - oldValue)")

            }

        }

    }

}

let NewCounter = Samplepgm()

NewCounter.counter = 100

NewCounter.counter = 800


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值