标签:
/// `重写`构造函数
///
/// - parameter dict: 字典
///
/// - returns: Person 对象
init(dict: [String: AnyObject]) {
setValuesForKeysWithDictionary(dict)
}
原因:
运行时
,动态向对象发送 setValue:ForKey:
方法,为对象的属性设置数值实例化
添加 super.init()
同样会报错
原因:
必选属性
必须在调用父类构造函数之前完成初始化分配工作将必选参数修改为可选参数,调整后的代码如下:
/// 个人模型
class Person: NSObject {
/// 姓名
var name: String?
/// 年龄
var age: Int?
/// `重写`构造函数
///
/// - parameter dict: 字典
///
/// - returns: Person 对象
init(dict: [String: AnyObject]) {
super.init()
setValuesForKeysWithDictionary(dict)
}
}
运行测试,仍然会报错
错误信息:this class is not key value coding-compliant for the key age.
-> 这个类的键值 age 与 键值编码不兼容
可选
的概念/// 姓名
var name: String?
/// 年龄
var age: Int = 0
/// `重写`构造函数
///
/// - parameter dict: 字典
///
/// - returns: Person 对象
init(dict: [String: AnyObject]) {
super.init()
setValuesForKeysWithDictionary(dict)
}
提示:在定义类时,基本数据类型属性一定要设置初始值,否则无法正常使用 KVC 设置数值
init(dict: [String: AnyObject]) {
super.init()
setValuesForKeysWithDictionary(dict)
}
override func setValue(value: AnyObject?, forKey key: String) {
print("Key \(key) \(value)")
super.setValue(value, forKey: key)
}
// `NSObject` 默认在发现没有定义的键值时,会抛出 `NSUndefinedKeyException` 异常
override func setValue(value: AnyObject?, forUndefinedKey key: String) {
print("UndefinedKey \(key) \(value)")
}
setValuesForKeysWithDictionary
会按照字典中的 key
重复调用 setValue:forKey
函数forUndefinedKey
函数,程序会直接崩溃
NSUndefinedKeyException
异常forUndefinedKey
,会保证 setValuesForKeysWithDictionary
继续遍历后续的 key
forUndefinedKey
,子类可以不必再实现此函数/// 学生类
class Student: Person {
/// 学号
var no: String?
}
Designated
convenience
关键字修饰的构造方法就是便利构造函数nil
self.init()
重写
或者 super
/// `便利构造函数`
///
/// - parameter name: 姓名
/// - parameter age: 年龄
///
/// - returns: Person 对象,如果年龄过小或者过大,返回 nil
convenience init?(name: String, age: Int) {
if age < 20 || age > 100 {
return nil
}
self.init(dict: ["name": name, "age": age])
}
注意:在 Xcode 中,输入
self.init
时没有智能提示
/// 学生类
class Student: Person {
/// 学号
var no: String?
convenience init?(name: String, age: Int, no: String) {
self.init(name: name, age: age)
self.no = no
}
}
指定构造函数
或者用 self.
的方式调用父类的便利构造函数
nil
在 iOS 开发中,懒加载是无处不在的
lazy var person: Person = {
print("懒加载")
return Person()
}()
let personFunc = { () -> Person in
print("懒加载")
return Person()
}
lazy var demoPerson: Person = self.personFunc()
lazy var demoPerson: Person = Person()
getter & setter
很少用,以下代码仅供了解private var _name: String?
var name: String? {
get {
return _name
}
set {
_name = newValue
}
}
var title: String {
get {
return "Mr " + (name ?? "")
}
}
var title: String {
return "Mr " + (name ?? "")
}
var title2: String {
return "Mr" + (name ?? "")
}
lazy var title: String = {
return "Mr " + (self.name ?? "")
}()
标签:
原文地址:http://www.cnblogs.com/like359881584/p/5771406.html