zoukankan      html  css  js  c++  java
  • Swift中类的使用

    主要内容

    • 类的介绍和定义
    • 类的属性
    • 类的构造函数

    一. 类的介绍和定义

    • Swift也是一门面向对象开发的语言
    • 面向对象的基础是类,类产生了对象
    在Swift中如何定义类呢?
    • class是Swift中的关键字,用于定义类
    class 类名 : SuperClass {
        // 定义属性和方法
    }
    
    注意:
    • 定义的类,可以没有父类.那么该类是rootClass
    • 通常情况下,定义类时.继承自NSObject(非OC的NSObject)

    二. 如何定义类的属性

    类的属性介绍

    • Swift中类的属性有多种
    • 存储属性:存储实例的常量和变量
    • 计算属性:通过某种方式计算出来的属性
    • 类属性:与整个类自身相关的属性
    存储属性
    • 存储属性是最简单的属性,它作为类实例的一部分,用于存储常量和变量
    • 可以给存储属性提供一个默认值,也可以在初始化方法中对其进行初始化
    • 下面是存储属性的写法
     - age和name都是存储属性,用来记录该学生的年龄和姓名
     - chineseScore和mathScore也是存储属性,用来记录该学生的语文分数和数学分数
    class Student : NSObject {
        // 定义属性
        // 存储属性
        var age : Int = 0
        var name : String?
        var chineseScore : Double = 0.0
        var mathScore : Double = 0.0
    }
    
    // 创建学生对象
    let stu = Student()
    
    // 给存储属性赋值
    stu.age = 10
    stu.name = "why"
    
    stu.chineseScore = 89.0
    stu.mathScore = 98.0
    

    计算属性

    • 计算属性并不存储实际的值,而是提供一个getter和一个可选的setter来间接获取和设置其它属性
    • 计算属性一般只提供getter方法
    • 如果只提供getter,而不提供setter,则该计算属性为只读属性,并且可以省略get{}
    下面是计算属性的写法
     - averageScore是计算属性,通过chineseScore和mathScore计算而来的属性
     - 在setter方法中有一个newValue变量,是系统指定分配的
    class Student : NSObject {
        // 定义属性
        // 存储属性
        var age : Int = 0
        var name : String?
    
        var chineseScore : Double = 0.0
        var mathScore : Double = 0.0
    
        // 计算属性
        var averageScore : Double {
            get {
                return (chineseScore + mathScore) / 2
            }
    
            // 没有意义,因为之后获取值时依然是计算得到的
            // newValue是系统分配的变量名,内部存储着新值
            set {
                self.averageScore = newValue
            }
        }
    }
    
    // 获取计算属性的值
    print(stu.averageScore)
    

    类属性

    • 类属性是与类相关联的,而不是与类的实例相关联
    • 所有的类和实例都共有一份类属性.因此在某一处修改之后,该类属性就会被修改
    • 类属性的设置和修改,需要通过类来完成
    • 面是类属性的写法
    • 类属性使用static来修饰
    • courseCount是类属性,用来记录学生有多少门课程
    class Student : NSObject {
        // 定义属性
        // 存储属性
        var age : Int = 0
        var name : String?
    
        var chineseScore : Double = 0.0
        var mathScore : Double = 0.0
    
        // 计算属性
        var averageScore : Double {
            get {
                return (chineseScore + mathScore) / 2
            }
    
            // 没有意义.newValue是系统分配的变量名,内部存储着新值
            set {
                self.averageScore = newValue
            }
        }
    
        // 类属性
        static var corseCount : Int = 0
    }
    
    // 设置类属性的值
    Student.corseCount = 3
    // 取出类属性的值
    print(Student.corseCount)
    

    监听属性的改变

    • 在OC中我们可以重写set方法来监听属性的改变
    • Swift中可以通过属性观察者来监听和响应属性值的变化
    • 通常是监听存储属性和类属性的改变.(对于计算属性,我们不需要定义属性观察者,因为我们可以在计算属性的setter中直接观察并响应这种值的变化)
    • 我们通过设置以下观察方法来定义观察者
    • willSet:在属性值被存储之前设置。此时新属性值作为一个常量参数被传入。该参数名默认为newValue,我们可以自己定义该参数名
    • didSet:在新属性值被存储后立即调用。与willSet相同,此时传入的是属性的旧值,默认参数名为oldValue
    • willSet与didSet只有在属性第一次被设置时才会调用,在初始化时,不会去调用这些监听方法
    监听的方式如下:
    • 监听age和name的变化
    class Person : NSObject {
        var name : String? {
            // 可以给newValue自定义名称
            willSet (new){ // 属性即将改变,还未改变时会调用的方法
                // 在该方法中有一个默认的系统属性newValue,用于存储新值
                print(name)
                print(new)
            }
            // 可以给oldValue自定义名称
            didSet (old) { // 属性值已经改变了,会调用的方法
                // 在该方法中有一个默认的系统属性oldValue,用于存储旧值
                print(name)
                print(old)
            }
        }
        var age : Int = 0
        var height : Double = 0.0
    }
    
    let p : Person = Person()
    
    // 在赋值时,监听该属性的改变
    // 在OC中是通过重写set方法
    // 在swift中,可以给属性添加监听器
    p.name = "cj"
    
    //p.name = "jj"
    
  • 相关阅读:
    createjs 利用createjs 写拼图功能
    canvas 利用canvas中的globalCompositeOperation 绘制刮奖 效果
    git 命令
    cmd 打开gitshell
    Grunt完成对LESS实时编译
    nodejs gulp less编辑
    canvas 绘制 矩形 圆形
    canvas绘制时钟
    juqery easyui
    vue-router(第2节课,妙味课堂)
  • 原文地址:https://www.cnblogs.com/chenjianjian/p/5464378.html
Copyright © 2011-2022 走看看