您好,登錄后才能下訂單哦!
小編這次要給大家分享的是詳解在Swift中使用KVO,文章內容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。
在文字的開頭,先說一個小細節,swift中聲明一個類,你可以集成自NSObject,也可以選擇忽略,二者有什么區別呢。根據自己的經驗,我得出以下結論。不足之處,請指出。exmple:我們聲明這樣一個類
class Person: NSObject { var name: String? override init() { super.init() } } 此類打印出的內存地址是0x00000fbd00007ffeefbfc240
這段代碼是不會報錯的,是一個典型的swift遺留ObjC語法的寫法,但是如果我們去掉NSObject并打印出他的內存地址,如下
class Person { var name: String? init() { } } 此類打印出的內存地址是0x00007ffeefbfc240
區別還有很多,平時在開發中大家可以多注意這一區別。個人偏向不繼承NSObject,尤其是我需要此類做一些騷操作時,比如KVO。
KVO是OC一個對象屬性的特性,由于是面向字符串,所以開發時需要尤其小心,這種奔潰只有執行到了才會報錯。聲明如下類:
class Person: NSObject { @objc var age: Int? var name: String? var observation: NSKeyValueObservation? override init() { super.init() self.observation = observe(\Person.age, options: .new, changeHandler: { (person, change) in print("Person.age的新值 = ", change.newValue as Any) }) } }
在外部我們,初始化一個對象,并對age進行賦值,如下
let person = Person() person.age = 18 person.setValue(100, forKey: "age")
程序執行后,(ÒωÓױ)!為什么只有一個打印?按理說是應該打印Person.age的新值 = 18
和Person.age的新值 = 100
的呀,然而并沒有:laughing:。問題出在哪,原來,swift中如果需要對一個值進行監聽,那么一定要記住2個關鍵詞
否則,
沒有@objc程序在監聽時會觸發奔潰;沒有dynamic則屬性的set方法不會生效,自然就沒有上面的打印,因為KVO的本質就是監聽屬性的set方法,而可變數組的增刪操作都不會生效;
但是為什么KVC的操作卻能生效呢?這是因為KVC內部的實現過程是
所以正確的寫法應該是
class Person: NSObject { @objc dynamic var age: Int? var name: String? var observation: NSKeyValueObservation? override init() { super.init() self.observation = observe(\Person.age, options: .new, changeHandler: { (person, change) in print("Person.age的新值 = ", change.newValue as Any) }) } }
看完這篇關于詳解在Swift中使用KVO的文章,如果覺得文章內容寫得不錯的話,可以把它分享出去給更多人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。