Swift—重写-备
=========================
重写实例属性
我们可以在子类中重写从父类继承来的属性,属性有实例属性和静态属性之分,他们在具体实现也是不同的。
实例属性的重写一方面可以重写getter和setter访问器,另一方面可以重写属性观察者。
计算静态属性需要使用getter和setter访问器,而存储属性不需要。子类在继承父类后,也可以通过getter和setter访问器重写父类的存储属性和计算属性。
下面看一个示例:
- class Person {
- var name: String //存储属性
- var age: Int //存储属性
- func description() -> String {
- return "\(name) 年龄是: \(age)"
- }
- init (name: String, age: Int) {
- self.name = name
- self.age = age
- }
- }
- class Student: Person {
- var school: String
- override var age: Int { //重写属性前面要添加override关键字
- get {
- return super.age
- }
- set {
- super.age = newValue < 8 ? 8: newValue
- }
- }
- convenience init() {
- self.init(name: "Tony", age: 18, school: "清华大学")
- }
- init (name: String, age: Int, school: String) {
- self.school = school
- super.init(name: name, age: age)
- }
- }
- let student1 = Student()
- print("学生年龄:\(student1.age)")
- student1.age = 6
- print("学生年龄:\(student1.age)")
从属性重写可见,子类本身并不存储数据,数据是存储在父类的存储属性中的。
以上示例是重写属性getter和setter访问器,我们还可以重写属性观察者,代码如下:
- class Person {
- var name: String
- var age: Int
- func description() -> String {
- return "\(name) 年龄是: \(age)"
- }
- init (name: String, age: Int) {
- self.name = name
- self.age = age
- }
- }
- class Student: Person {
- var school: String
- override var age: Int { //重写了age属性观察者
- willSet { //如果只关注修改之前的调用,可以只重写willSet观察者
- print("学生年龄新值:\(newValue)")
- }
- didSet{ //如果只关注修改之后的调用,可以只重写didSet观察者
- print("学生年龄旧值:\(oldValue)")
- }
- }
- convenience init() {
- self.init(name: "Tony", age: 18, school: "清华大学")
- }
- init (name: String, age: Int, school: String) {
- self.school = school
- super.init(name: name, age: age)
- }
- }
- let student1 = Student()
- print("学生年龄:\(student1.age)")
- Student1.age = 6
- print("学生年龄:\(student1.age)")
代码Student1.age = 6修改了age属性,修改前后的输出结果如下:
学生年龄新值:6
学生年龄旧值:18
重写静态属性
在类中静态属性定义使用class或static关键字,但是使用哪一个要看子类中是否重写该属性。class修饰的属性可以被重写,static关键字就不能被重写。
示例代码如下:
- class Account {
- var amount: Double = 0.0 // 账户金额
- var owner: String = "" //账户名
- var interestRate: Double = 0.0668 //利率
- //class不能换成static
- class var staticProp: Double { //静态属性staticProp
- return 0.0668 * 1_000_000
- }
- var instanceProp: Double {
- return self.interestRate * self.amount
- }
- }
- class TermAccount: Account {
- //class换成static
- override class var staticProp: Double { //重写静态属性staticProp
- return 0.0700 * 1_000_000
- }
- }
- //访问静态属性
- print(Account.staticProp)
- print(TermAccount.staticProp)
由于要被重写所以代码class var staticProp: Double 中的class不能换成static。代码overrideclass var staticProp: Double中的静态属性staticProp可以使用class或static,除非在TermAccount的子类中重写属性staticProp。
================================
重写实例方法
在子类中重写从父类继承来的实例方法和静态方法。先介绍实例方法的重写。
下面看一个示例:
- class Person {
- var name: String
- var age: Int
- func description() -> String { //实例方法
- return "\(name) 年龄是: \(age)"
- }
- class func printClass() ->() { //静态方法
- print( "Person 打印...")
- }
- init (name: String, age: Int) {
- self.name = name
- self.age = age
- }
- }
- class Student: Person {
- var school: String
- convenience init() {
- self.init(name: "Tony", age: 18, school: "清华大学")
- }
- init (name: String, age: Int, school: String) {
- self.school = school
- super.init(name: name, age: age)
- }
- override func description() -> String { //重写实例方法description,重写的方法前面要添加关键字override
- print("父类打印 \(super.description())")
- return "\(name) 年龄是: \(age), 所在学校: \(school)。"
- }
- override class func printClass() ->() { //重写静态方法printClass
- print( "Student 打印...")
- }
- }
- let student1 = student()
- print("学生1:\(student1.description())") //调用了description方法
- Person.printClass()
- Student.printClass()
使用super.description()语句调用父类的description方法,其中super指代父类实例。
重写静态方法printClass,在静态方法中不能访问实例属性。
调用了description方法。由于在子类中重写了该方法,所以调用的是子类中的description方法。输出结果是:
父类打印 Tony 年龄是: 18
学生1:Tony 年龄是: 18, 所在学校: 清华大学。
为了测试静态方法重写,调用Person.printClass()语言,它是调用父类的printClass静态方法,输出结果是:
Person 打印...
调用Student.printClass()语言,它是调用子类的printClass静态方法,输出结果是:
Student 打印...
重写静态方法
与类的静态属性定义类似,静态方法使用class或static关键字,但是使用哪一个要看子类中是否重写该方法。class修饰的静态方法可以被重写,static关键字就不能被重写。
示例代码如下:
- class Account {
- var owner: String = "Tony" //账户名
- //不能换成static
- class func interestBy(amount: Double) -> Double { //静态方法
- return 0.08886 * amount
- }
- }
- class TermAccount: Account {//定期账户
- //可以换成static
- override class func interestBy(amount: Double) -> Double { //静态方法
- return 0.09 * amount
- }
- }
- //调用静态方法
- print(Account.interestBy(10_000.00 ))
- print(TermAccount.interestBy(10_000.00 ))
由于被重写所以代码class funcinterestBy(amount: Double) -> Double中的class不能换成static。静态方法interestBy可以使用class或static,除非在TermAccount的子类中重写方法interestBy。
==============================================
下标是一种特殊属性。子类属性重写是重写属性的getter和setter访问器,对下标的重写也是重写下标的getter和setter访问器。
下面看一个示例:
- class DoubleDimensionalArray {
- let rows: Int, columns: Int
- var grid: [Int]
- init(rows: Int, columns: Int) {
- self.rows = rows
- self.columns = columns
- grid = Array(count: rows * columns, repeatedValue: 0)
- }
- subscript(row: Int, col: Int) -> Int { //定义下标
- get {
- return grid[(row * columns) + col]
- }
- set {
- grid[(row * columns) + col] = newValue
- }
- } //定义下标
- }
- class SquareMatrix: DoubleDimensionalArray {
- override subscript(row: Int, col: Int) -> Int { //重写父类下标
- get {
- return super.grid[(row * columns) + col]
- }
- set {
- super.grid[(row * columns) + col] = newValue * newValue
- }
- }
- }
- var ary2 = SquareMatrix(rows: 5, columns: 5)
- for var i = 0; i < 5; i++ {
- for var j = 0; j < 5; j++ {
- ary2[i,j] = i + j
- }
- }
- for var i = 0; i < 5; i++ {
- for var j = 0; j < 5; j++ {
- print("\t\t \(ary2[i,j])")
- }
- print("\n")
- }
其中super.grid[(row * columns) + col]语句中使用super调用父类的grid属性。
其中super.grid[(row * columns) + col] = newValue * newValue语句是给父类的grid属性赋值。
Swift—重写-备的更多相关文章
- Swift - 重写UIKit框架类的init初始化方法(以UITabBarController为例)
原来写了篇文章讲UITabBarController的用法,当时是从UIViewController跳转到UITabBarController页面,代码如下: 1 self.presentViewCo ...
- 用Swift重写公司OC项目(Day1)--程序的AppIcon与LaunchImage如何设置
公司之前的APP呢经过了两次重写,都是使用OC由本人独立开发的,不过这些东西我都不好意思说是自己写的,真心的一个字:丑!!! 客观原因来说主要是公司要的特别急,而且注重的是功能而非效果,公司的美工之前 ...
- Swift—静态方法-备
静态方法与静态属性类似,Swift中定义了静态方法,也称为类型方法.静态方法的定义与静态属性类似,枚举和结构体的静态方法使用的关键字是static:类静态方法使用的关键字是class或static,如 ...
- Uber使用Swift重写APP的踩坑经历及解决方案(转载)
本文出自Uber移动架构和框架组负责人托马斯·阿特曼于2016年在湾区Swift峰会上的演讲,分享了使用Swfit重写Uber的好与坏.以下为译文: 我是托马斯·阿特曼,目前是Uber移动架构和框架组 ...
- 用Swift重写公司OC项目(Day2)--创建OC与Swift的桥接文件,进而调用OC类库
昨天把项目中的图标以及启动转场图片弄好了,那么今天,我们可以开始慢慢进入到程序的编写当中了. 由于swift较新,所以类库还不够完善,但是不用担心,苹果早就出了解决方案,那就是使用桥接文件,通过桥接文 ...
- Swift—析构函数-备
与构造过程相反,实例最后释放的时候,需要清除一些资源,这个过程就是析构过程.在析构过程中也会调用一种特殊的方法deinit,称为析构函数.析构函数deinit没有返回值,也没有参数,也不需要参数的小括 ...
- Swift—下标-备
看下面的示例代码是不是使用过: var studentList: String[] = ["张三","李四","王五"] studentL ...
- swift闭包-备
我给Swift 中的闭包一个定义:闭包是自包含的匿名函数代码块,可以作为表达式.函数参数和函数返回值,闭包表达式的运算结果是一种函数类型. Swift中的闭包类似于Objective-C中的代码块.J ...
- Swift重写UIButton的图片和标题的位置
import UIKit class ResetBtn: UIButton { let IMAGE_RATIO :CGFloat = 0.7 // 图片占整个按钮高度的比例 let TITLE_FON ...
随机推荐
- jQuery Builder
简介 作用:customize jQuery,可以仅包含自己想要的模块 jQuery Builder lets you easily build a custom version of jQuery ...
- HDOJ(HDU) 2093 考试排名(Arrays.sort排序、类的应用)
Problem Description C++编程考试使用的实时提交系统,具有即时获得成绩排名的特点.它的功能是怎么实现的呢? 我们做好了题目的解答,提交之后,要么"AC",要么错 ...
- Matlab:回归分析(1)
1.多元线性回归 %数据的输入 x = [ ]; y = [ ]; %转换为列向量 X = [ones(,) x']; Y = y'; %回归分析及检验 [b, bint, r, rint, stat ...
- STL——heap的4大操作
STL的堆操作 STL里面的堆操作一般用到的只有4个:make_heap();.pop_heap();.push_heap();.sort_heap(); 他们的头文件函数是#include < ...
- POJ 2718 穷举
题意:给定一组数字,如0, 1, 2, 4, 6, 7,用这些数字组成两个数,并使这两个数之差最小.求这个最小差.在这个例子上,就是204和176,差为28. 分析:首先可以想到,这两个数必定是用各一 ...
- escape encodeURI encodeURIComponent区别
escape() 函数可对字符串进行编码,这样就可以在所有的计算机上读取该字符串.使用unescape来解码. 有效的URI(统一资源标示符)是不能包含某些字符的,如空格,所以需要进行编码,编码方法有 ...
- laravel实现数据库读写分离配置或者多读写分离配置
config\database.php里 读写分离:'mysql' => array( 'read' => array( 'host' => '192.168.1.1', ), 'w ...
- Android开发/源代码资源汇总
全网最全的Android游戏源代码汇总 mod=viewthread&tid=5080&fromuid=5" target="_blank">htt ...
- Verilog中锁存器与多路选择器
Verilog中锁存器与多路选择器 Verilog是一种硬件描述语言,它代表的是硬件. Verilog代表的就是逻辑门和连接线. 对于一个always@(*)控制的块而言,只要块中的表达式包含的任意的 ...
- memcache如何模糊查询
是新的方法,还是get方法本身就有这个功能? 需要用到递归遍历的方法,将所有的key-value扫描出来.