Swift-10(属性、方法和下标)

每日一句:你若不想做,会找一个或无数个借口;你若想做,会想一个或无数个办法。

u=1408371311,2263836872&fm=26&gp=0.jpg

一、属性

属性将值与特定的类、结构体或者枚举关联。存储属性会将常量和变量存储为实例的一部分,而计算属性则是直接计算值。计算属性可以用于类、结构体和枚举,而存储属性只能用于类和结构体

1.存储属性

  • 存储属性可以是变量(var)或者常量(let)
    struct Person {
        var name: String?
        let age: Int?
    }
    var jone = Person(name: "jone", age: 18);
    jone.name = "tom"
    print(jone)
  • 延迟加载存储属性
    延迟加载存储属性只是在第一次被调用的时候才会计算其初始值。在属性声明前加上lazy
    attention(注意):延迟加载存储属性必须要用var,因为属性的初始值要等构造器完成之后才能赋值,如果延迟属性在没有赋值之前,被多线程同时访问的话,就无法保证该属性就被赋值了一次

    2.计算属性

  • 计算属性并不是直接存储值,而是提供一个getter和一个可选的setter,来间接获取值或者设置值
//计算属性
struct Origin {
    var x = 0.0,y = 0.0
}

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

struct Rect {
    var origin = Origin();
    var size = Size();
    var center: Origin {
        get {
            let centerX = origin.x + size.width/2.0;
            let centerY = origin.y + size.height/2.0;
            return Origin(x: centerX, y: centerY);
        }
        set(newRect) {
            origin.x = newRect.x - size.width/2.0;
            origin.y = newRect.y - size.height/2.0;
        }
    }
}

var circle = Rect(origin: Origin(x: 0, y: 0), size: Size(width: 50, height: 50));
print(circle.center)
circle.center = Origin(x: 20, y: 20);
print(circle.center)
  • 简化Setter声明
    如果setter方法中没有声明新值的名字,那么可以使用newvalue
set() {
  origin.x = newValue.x - size.width/2.0; 
  origin.y = newValue.y - size.height/2.0;
}
  • 简化getter
    如果getter中是单一表达式的话,可以不需要return
get {
  Origin(x: origin.x + size.width/2.0, y: origin.y + size.height/2.0)
}
  • 只读属性
    该属性是实现了getter,没有实现setter

3.属性观察

当属性每次被设置值的时候,都会调用属性观察器,即使新值和老值都一样的情况下。你可以为一个属性添加一个或者两个属性观察器,willSet和didSet,willSet实在新值赋值之前调用,didSet是在新值赋值之后调用
attention(注意): 在父类初始化方法调用之后,子类构造器中给父类属性赋值会调用willSet和didSet。但是父类初始化方法调用之前,是不会调用的。

struct Animation {
    var name: String {
        willSet {
            if newValue == "jone" {
                print("haha")
            } else {
                print("xixi")
            }
        }
        didSet {
            print(name)
        }
    }
}

var cat = Animation(name: "cat");
cat.name = "cat";

4.属性包装

属性包装器在管理属性如何存储和定义属性的代码之间添加了一个分隔层.

5.全局变量和局部变量

和OC是一样的,全局变量是在函数、方法、闭包或任何类型之外定义的变量。局部变量是在函数、方法或闭包内部定义的变量。

6.类型属性

你也可以为类型本身定义属性,无论创建了多少个该类型的实例,这些属性都只有唯一一份。这种属性就是类型属性。

二、方法

1、定义:方法是与某些特定类型相关联的函数。

2、与OC的区别是,swift中结构体和枚举中都可以定义方法

3、实例方法与类型方法

//实例方法
class Student {
    var age = 1;
    func increaceAge() {
        self.age+=1;
    }
    func resetAge() {
        self.age = 18;
    }
    class func girlStudent() {
        print("I,m")
    }
}

var student = Student();
student.increaceAge();
student.resetAge();
print(student.age)

//类型方法
Student.girlStudent();

三、下标

1. 下标可以定义在类、结构体和枚举中,是访问集合、列表和序列中元素的快捷方式。定义下标用subscript

2. 下标语法

subscript(index: Int) -> Int {
    get {
      // 返回一个适当的 Int 类型的值
    }
    set(newValue) {
      // 执行适当的赋值操作
    }
}

gitHub地址:https://github.com/kingbroad/SwiftStudy(欢迎👏关注❤️)

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,284评论 6 506
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,115评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,614评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,671评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,699评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,562评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,309评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,223评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,668评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,859评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,981评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,705评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,310评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,904评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,023评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,146评论 3 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,933评论 2 355