1.构照方法子类构照
2. 在Person类重写了init构照方法然后进行添加属性以及赋值
3.然后创建一个Student类继承Person类然后进行调用Person的构照方法来添加属性
4.然后调用子类进行赋值
代码如下:
/*
构造函数 : 分配内存空间 设置初始值
()
在 swift 中 所有的构造方法 都是 init
*/
import UIKit
class Person: NSObject {
var name: String
var age: Int
//表示重写 表示重写父类的构造函数
//父类已经提供函数 子类需要对父类的函数进行扩展
//方法内 可以super.
构造函数 : 分配内存空间 设置初始值
()
在 swift 中 所有的构造方法 都是 init
*/
import UIKit
class Person: NSObject {
var name: String
var age: Int
//表示重写 表示重写父类的构造函数
//父类已经提供函数 子类需要对父类的函数进行扩展
//方法内 可以super.
override init() {
print("Person init")
name = "刘亦菲"
age = 30
// super.init()
// name = "刘亦菲"
}
name = "刘亦菲"
age = 30
// super.init()
// name = "刘亦菲"
}
}
———————Student类
class Student: Person {
var no: String
override init() {
print("Student init")
no = "007"
//隐式生成 super.init 在Xcode 7 beta5 在之前的版本都需要手动添加
//建议自己手动加上 super.init
// super.init()
}
}
————ViewDidload
class ViewController: UIViewController {
override func viewDidLoad() {
super.viewDidLoad()
//alloc init = ()
//自定义对象 打印内存是内存地址
let p = Student()
print(p.name, p.age,p.no)
}
}
override func viewDidLoad() {
super.viewDidLoad()
//alloc init = ()
//自定义对象 打印内存是内存地址
let p = Student()
print(p.name, p.age,p.no)
}
}
2.重载
/*
构造函数 : 分配内存空间 设置初始值
()
在swift中 所有的构造方法 都是init
构造函数的责任就是 一定构造一个对象出来
重载: 函数名相同 参数的类型 以及参数的个数不同 就形成重载 是面向对象最显著的标志
极大简化 需要记住的函数名
一旦重载构造函数 默认的构造函数就不能访问
*/
import UIKit
构造函数 : 分配内存空间 设置初始值
()
在swift中 所有的构造方法 都是init
构造函数的责任就是 一定构造一个对象出来
重载: 函数名相同 参数的类型 以及参数的个数不同 就形成重载 是面向对象最显著的标志
极大简化 需要记住的函数名
一旦重载构造函数 默认的构造函数就不能访问
*/
import UIKit
class Person: NSObject {
var name: String
var age: Int
//表示重写 表示重写父类的构造函数
//父类已经提供函数 子类需要对父类的函数进行扩展
//父类已经提供函数 子类需要对父类的函数进行扩展
//方法内 可以super.
// override init() {
//
// print("Person init")
// name = "刘亦菲"
// age = 30
//// super.init()
//// name = "刘亦菲"
// name = "刘亦菲"
// age = 30
//// super.init()
//// name = "刘亦菲"
// }
//构造方法
init(name: String, age: Int) {
//当属性名和参数名相同时 需要加上 self来区分
self.name = name
self.age = age
super.init()
}
init(name: String, age: Int) {
//当属性名和参数名相同时 需要加上 self来区分
self.name = name
self.age = age
super.init()
}
}
3.KVC重载
//默认值是 nil 没有分配空间 运行时临时分配内存空间
var name: String?
// this class is not key value coding-compliant for the key age
//在给对象转发 setValue: forKey: 判断对象的属性 是否为空 如果为空 就调用其构造方法 实例化
//基本数据类型 没有构造方法 不会被创建
// age和kVC不兼容
//基本数据类型 需要设置初始值
var age: Int = 0
//表示重写 表示重写父类的构造函数
//父类已经提供函数 子类需要对父类的函数进行扩展
//方法内 可以super.
// override init() {
//
//
// print("Person init")
// name = "刘亦菲"
// age = 30
//// super.init()
//// name = "刘亦菲"
// }
//构造方法
init(name: String, age: Int) {
//当属性名和参数名相同时 需要加上 self来区分
self.name = name
self.age = age
super.init()
}
//KVC构造
init(dict: [String : AnyObject]) {
//KVC是OC特有的机制 OC可以和swift共存
//在运行时 给'对象' 转发 setValue: forKey:
//KVC 通过键值编码 给对象的属性设置初始值
super.init()
setValuesForKeysWithDictionary(dict)
}
//这个方法会默认存在全体的属性
override func setValue(value: AnyObject?, forKey key: String) {
print(value,key)
super.setValue(value, forKey: key)
}
//过滤掉 不存的在属性对应的key
override func setValue(value: AnyObject?, forUndefinedKey key: String) {
print(value,key)
// super.setValue(value, forUndefinedKey: key)
}
var name: String?
// this class is not key value coding-compliant for the key age
//在给对象转发 setValue: forKey: 判断对象的属性 是否为空 如果为空 就调用其构造方法 实例化
//基本数据类型 没有构造方法 不会被创建
// age和kVC不兼容
//基本数据类型 需要设置初始值
var age: Int = 0
//表示重写 表示重写父类的构造函数
//父类已经提供函数 子类需要对父类的函数进行扩展
//方法内 可以super.
// override init() {
//
//
// print("Person init")
// name = "刘亦菲"
// age = 30
//// super.init()
//// name = "刘亦菲"
// }
//构造方法
init(name: String, age: Int) {
//当属性名和参数名相同时 需要加上 self来区分
self.name = name
self.age = age
super.init()
}
//KVC构造
init(dict: [String : AnyObject]) {
//KVC是OC特有的机制 OC可以和swift共存
//在运行时 给'对象' 转发 setValue: forKey:
//KVC 通过键值编码 给对象的属性设置初始值
super.init()
setValuesForKeysWithDictionary(dict)
}
//这个方法会默认存在全体的属性
override func setValue(value: AnyObject?, forKey key: String) {
print(value,key)
super.setValue(value, forKey: key)
}
//过滤掉 不存的在属性对应的key
override func setValue(value: AnyObject?, forUndefinedKey key: String) {
print(value,key)
// super.setValue(value, forUndefinedKey: key)
}
}
5.懒加载
//swift中 懒加载有非常特殊的写法
//实际上懒加载是 闭包
lazy var nameLabel: UILabel = {
print("我懒了么")
let l = UILabel()
l.textAlignment = NSTextAlignment.Center
return l
}()
lazy var titleLabel: UILabel = UILabel()
override func viewDidLoad() {
super.viewDidLoad()
// print(nameLabel)
// print(nameLabel)
// print(nameLabel)
}
6.Swift单例
OC和Swift 的文件是可以共存的,但是需要桥接,,需要
//let 不可变 同样是线程安全的
var baseURL: String?
static let tools: SoundTools = { () -> SoundTools in
let instance = SoundTools()
instance.baseURL = "www.douniwan.com"
return instance
var baseURL: String?
static let tools: SoundTools = { () -> SoundTools in
let instance = SoundTools()
instance.baseURL = "www.douniwan.com"
return instance
}()
7.set方法和get方法
//只读属性 又叫做 计算性属性
//一旦只实实现了 get方法 默认的隐含形式 添加的set方法 就会失效
//并不会分配内存空间
var name: String? {
get {
return "zhangsan"
}
//一旦只实实现了 get方法 默认的隐含形式 添加的set方法 就会失效
//并不会分配内存空间
var name: String? {
get {
return "zhangsan"
}
}
//并不需要分配内存空间
// var title: String? {
// get {
// return "Boos" + (name ?? "")
// }
// var title: String? {
// get {
// return "Boos" + (name ?? "")
// }
// }
//简写方式
var title: String? {
return "Boos" + (name ?? "")
}
var model: NSObject? {
didSet {
//cell绑定数据
}
}
var title: String? {
return "Boos" + (name ?? "")
}
var model: NSObject? {
didSet {
//cell绑定数据
}
}