swift 中 set 和 get 方法

相比 Objective-C 中的 set 和 get 方法 ,swift 中的set 和 get  要复杂一点。 在swift 中主要分存储型属性 和  计算型属性 这两种 , 一般 我们只是给计算属性添加 get set  重写。 

DEMO下载 地址 :https://gitee.com/DeLongYang/iOSFundation 下的 setterAndGetter 工程。

打开 SetterAndGetterTests.swift 文件。进行 单元测试  。我们主要分几个不同的方面来进行测试

 1.0    

仅仅想获取 原来的值 其实意义不大  OC  中的明显的区别是 

swift 中我们 不能使用  _c 来表示 OC 中@property 修饰的变量值 。直接调用

    var c:Int{

        get{

            // 这里 不论是 c 还是 self.c 都会造成 crash  原因是方法的死循环

            // 而且 不能像 OC 中 写上 _c

            return 1

          //   return self.c  不论是 c 还是 self.c 都会造成 crash  原因是方法的死循环

          //  return c 不论是 c 还是 self.c 都会造成 crash  原因是方法的死循环

        }


        set{

            // 我们测试 写上 self.c = newValue 和 不写 都会造成 crash

            // 而且 不能像 OC 中 写上 _c

            //  c  = newValue  造成 crash  原因是方法的死循环

            a= newValue

            print("Recived new value", newValue, " and stored into 'A' ")

        }

    }


2.0  由于上面提到的原因  重写的时候 我们使用 额外的一个变量来重写

// 使用了 外部的一个变量来重写了这个 方法

    var _tittle:String?

    var tittle:String?{


        set{


            _tittle=newValue

        }

        get{

            return_tittle

        }

    }


3.0   如果只重写 get 方法,默认为 readOnly

    var age:Int?{

        return20

    }

如果对  age 赋值 会造成 IDE 报错 

4.0 存储属性: 就是存储一个变量 或 常量  懒加载也属于存储型属性 类似于OC中的方法

 let aaa ="aaa"

    lazy var ccc:[TestModel] = {

        lettestModel =TestModel()

        vararr = [TestModel]()

        for_in0...99{

            arr.append(testModel)

        }

        //

        return arr

    }()

5.0   swift 中使用了willset 和 didSet 这连个特性 来见识属性的除初始化之外的 属性值变化

 和 OC 比较,我们可以在didSet 里面执行一些改变UI的操作

 var newAge:String?{


        willSet{

            //

            print("===========")

        }


        didSet{

            print("did set "+newAge!)

        }

    }

推荐阅读更多精彩内容