389,swift中属性的重载(计算属性和存储属性的重载:关键字override)面试点:父类的存储性属性可以重写成子类的计算属性,但是不可以在重写成子类的存储性属性,不可以将继承来的读写属性重...

引入

属性继承:子类可以继承父类的属性,包括存储属性、计算属性和类型属性,还可以继承父类的属性观察器。
属性重写需要遵循一定原则,不然就会报错

属性重写原则

重写使用override关键字
1、无论继承的是存储属性还是计算属性,子类都可以通过提供getter和setter对属性进行重写
2、可以将一个继承的属性重写为一个读写属性
3、 不可以将继承来的读写属性重写为只读属性
4、如果重写时提供了setter方法,一定要提供getter方法

属性观察器重写

1、无论父类有没有为该属性添加属性观察器,子类都可以添加属性观察器
2、如果父类已经添加了属性观察器,当属性发生变化时,父类与子类都会得到通知 父类仍然可以监听到属性的变化

class Student {
   
    //存储属性
    var age :Int = 0
    var chineseScore :Double = 0.0
    var englishScore :Double = 0.0
    //计算属性
    var averageScore :Double {//注意没有等号
        
        //访问(获取)调用get
        get{
            
            print("get") //只写这一句为什么报错?
            
            return (chineseScore + englishScore) / 2  //必须加上return ,因为拿到一个值返回。
        }
        
        //设置值的时候
        set{
            
            print("set")
            print("set\(newValue)")
            //千万不要在这里设置值 会死循环  外部参数起名字newvalue
            //self.averageScore = newValue
        }
        
    }
    //只读计算属性
    var averageScore2 :Double {
        
        return (chineseScore + englishScore) / 2
    }
    
    //类属性
    static var couseCount  = 3
    
    
    //懒加载属性
    lazy var courses :[String] = {
        
        
        ()->[String] in
        
        print("懒加载属性")
        return ["java", "html", "swift"]
    }()//()代表闭包执行
    
    //属性观察器-有的属性很重要,我希望关注每一次赋值的变化。 水晶球: 了解你的过去和将来
    //验证willSet和didSet作用
    //内置变量:newValue oldValue
    var name:String = "tt" {
        
        //newValue
        willSet{
            print("父类willSet被调用,newValue\(newValue)")
        }
        
        //oldValue
        didSet{
            
            print("父类didSet被调用,oldValue\(oldValue)")
        }
    }
   
}

//属性的继承与重写
class SeniorStudent : Student{
    
    //子类都可以通过提供getter和setter对属性进行重写
    override var chineseScore: Double{
        
        get{
            
            return 90.5
        }
        
        set{
            
            
        }
        
    }
    
    //不可以将继承来的读写属性重写为只读属性
    override var averageScore: Double{
        
        get{
            
            return 90.5
        }
        set{
                   
                   
        }
    }
    
    //如果父类已经添加了属性观察器,当属性发生变化时,父类与子类都会得到通知
   
    override var name:String{
        
        //newValue
        willSet{
            print("子类willSet被调用,newValue\(newValue)")
        }
        
        //oldValue
        didSet{
            print("子类didSet被调用,oldValue\(oldValue)")
        }
    }

    
}


var seniorStudent = SeniorStudent()
seniorStudent.name = "Wangwu"
截屏2020-12-27 上午11.48.16.png
截屏2020-12-27 上午11.48.27.png
截屏2020-12-27 上午11.48.36.png

计算属性常用的地方

这个功能的重点作用应该是在计算上。

对于一般的属性,要么直接存一个,要么直接读一个,计算属性则可以根据所设置内容,进行一些修改或计算之类的, 比如:

import UIKit
 
class sample {
     
    var no1 = 0.0, no2 = 0.0
    var length = 300.0, breadth = 150.0
     
    var middle:(Double,Double) {
         
        get {
            return(length / 2, breadth / 2)
        }
         
        // 如果没有加上括号, 那么默认就是 set(newValue) {}
        set {
            // 可以在set方法里动态修改其他属性和本属性
            no1 = newValue.0-(length / 2)
            no2 = newValue.1-(breadth / 2)
        }
        
        // 补充
        // set方法也可以写成
        // set(value) {
        //     no1 = value.0-(length / 2)
        //     no2 = value.1-(breadth / 2)
        // }
    }
}
 
var result = sample()
print(result.middle)
result.middle = (0.0, 10.0)
print(result.no1)
print(result.no2)
 
var result = sample()
print(result.middle)
result.middle = (0.0, 10.0)
print(result.no1)
print(result.no2)
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,080评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,422评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,630评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,554评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,662评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,856评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,014评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,752评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,212评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,541评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,687评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,347评论 4 331
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,973评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,777评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,006评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,406评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,576评论 2 349

推荐阅读更多精彩内容