swift中AnyObject和Any的介紹與區(qū)別詳解
誕生
swift 作為新起步的語言,必然拋不掉一些歷史遺留包袱。用過 Objective-C 的同學(xué)肯定知道有一種叫做 id 的類型。他可以表示任意類的實(shí)例,編譯器不會(huì)對(duì)其類型聲明的變量進(jìn)行檢查。在用 swift 做 app 開發(fā)時(shí),為了能適配 Cocoa 架構(gòu),AnyObject 就誕生了。它可以代表任意 class 類型(用來替代OC中的 id)。
區(qū)別
在 Swift 中編譯器會(huì)對(duì) AnyObject 實(shí)例的方法調(diào)用做檢查,還會(huì)返回一個(gè) Optional 的結(jié)果。
原理
public typealias AnyObject // The protocol to which all class types implicitly conform.
由定義就可以看出它就是一個(gè)接口,所有的 class 都隱式地實(shí)現(xiàn)了這個(gè)借口。所以 AnyObject 只適用于 class 類型。但是 swift 中的基本類型都是 struct 類型,并不能用 AnyObject 來表示。所以官方又提出了一個(gè)更特殊的 Any 類型,它除了 class 以外還可以表示其他類型,可以說是任意類型(包括 struct,enum,func等)。
import UIKit class ViewController: UIViewController { override func viewDidLoad() { super.viewDidLoad() let swiftArr = ["a", "b", "c"] let swiftStr = "hello world" var array = [AnyObject]() array.append(swiftArr) array.append(swiftStr) } }
這種寫法是會(huì)報(bào)錯(cuò)的,String 不符合預(yù)期類型 AnyObject,并且系統(tǒng)提示了我們?cè)趺葱薷模?br />
Argument type 'String' does not conform to expected type 'AnyObject' Insert ' as AnyObject'
按提示修改后:
import UIKit class ViewController: UIViewController { override func viewDidLoad() { super.viewDidLoad() let swiftArr = ["a", "b", "c"] let swiftStr = "hello world" var array = [AnyObject]() array.append(swiftArr as AnyObject) array.append(swiftStr as AnyObject) } }
這里我們顯示的將 swift 中的 String 和 Array 轉(zhuǎn)成了 AnyObject。實(shí)際上 array 里面的元素已經(jīng)變成了 NSString 和 NSArray 了。
當(dāng)然我們還有另外的方式解決此問題,用 Any。
import UIKit class ViewController: UIViewController { override func viewDidLoad() { super.viewDidLoad() let swiftArr = ["a", "b", "c"] let swiftStr = "hello world" var array = [Any]() array.append(swiftArr) array.append(swiftStr) } }
可以看到結(jié)果全部是 swift 中的原生類型:
注意
- 只是用 swift 類型而不轉(zhuǎn)為 Cocoa 類型是會(huì)提升性能的,所以我們最好還是使用原生類型。
- 在 OC 和 swift 混編的工程中使用 AnyObject 和 Any 是在所難免的,但我們要盡量避免使用這兩者,swift 中最好明確地指出確定的類型。
- 如果我們的代碼經(jīng)常用到這兩者,意味著代碼可能在結(jié)構(gòu)和設(shè)計(jì)上存在問題。
下面來舉例說明:
1.Any -- 比如我們經(jīng)常使用的參數(shù)parameters
parameters = ["appId":"123456", "timestamp":203428394820, "version":"1.0", "appAuthToken":"7D8SF7D8VS8987D67687", "bizContent":["pageStart":1, "pageSize": "10","isTrue":true]] as [String : Any]
這里面包括了String,Int,Bool,Dictionnary四種類型的參數(shù),最后使用as [String : Any] ,就是說,parameters的key是String類型,但是value值可以是任何類型。
2.AnyObject -- 在做網(wǎng)絡(luò)請(qǐng)求的時(shí)候
typealias Complicate = (AnyObject) ->Void //請(qǐng)求回調(diào) var complicate : Complicate? func request(type:RequestType, URLString:String, parameters:[String : AnyObject], complicate:@escaping Complicate) -> Void { CK().maskShow() switch type { case .requestTypeGet: Alamofire.request(URLString, method: .get, parameters: parameters, encoding: JSONEncoding.default, headers: nil) .validate() .responseJSON { response in CK().dismissMask() switch response.result{ case .success: if let value = response.result.value{ //把得到的JSON數(shù)據(jù)轉(zhuǎn)為字典 complicate(value as AnyObject) } case .failure: () DMCAlertCenter.default().postAlert(withMessage: "網(wǎng)絡(luò)請(qǐng)求失敗") return } }
可以看到,在返回的json進(jìn)行回調(diào)的時(shí)候,由于value是JSON類型的實(shí)例,complicate(value as AnyObject), 就是將value作為AnyObject傳值出去。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對(duì)腳本之家的支持。
相關(guān)文章
swiftui開發(fā)之padding默認(rèn)值設(shè)置詳解
這篇文章主要為大家介紹了swiftui開發(fā)之padding默認(rèn)值設(shè)置詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09Spring中BeanFactory與FactoryBean的區(qū)別解讀
這篇文章主要介紹了Spring中BeanFactory與FactoryBean的區(qū)別解讀,Java的BeanFactory是Spring框架中的一個(gè)接口,它是用來管理和創(chuàng)建對(duì)象的工廠接口,在Spring中,我們可以定義多個(gè)BeanFactory來管理不同的組件,需要的朋友可以參考下2023-12-12iOS Swift UICollectionView橫向分頁滾動(dòng),cell左右排版問題詳解
UICollectionView是iOS中比較常見的一個(gè)控件,這篇文章主要給大家介紹了關(guān)于iOS Swift UICollectionView橫向分頁滾動(dòng),cell左右排版問題的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-12-12Swift類型創(chuàng)建之自定義一個(gè)類型詳解
這篇文章主要介紹了Swift類型創(chuàng)建之自定義一個(gè)類型詳解,本文講解了自定義原型、實(shí)現(xiàn)默認(rèn)值、支持基本布爾型初始化、支持Bool類型判斷、支持兼容各們各派的類型、完善OCBool的布爾基因體系等內(nèi)容,需要的朋友可以參考下2015-05-05在Swift中使用KVO的細(xì)節(jié)以及內(nèi)部實(shí)現(xiàn)解析(推薦)
這篇文章主要介紹了在Swift中使用KVO的細(xì)節(jié)以及內(nèi)部實(shí)現(xiàn)解析,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07Swift項(xiàng)目中利用SWRevealViewController實(shí)現(xiàn)側(cè)滑菜單
這篇文章主要介紹了Swift項(xiàng)目中利用SWRevealViewController實(shí)現(xiàn)側(cè)滑菜單,需要的朋友可以參考下2015-12-12