亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

在SWIFT中使用調度單例模型

在SWIFT中使用調度單例模型

森林海 2019-06-03 16:17:22
在SWIFT中使用調度單例模型我正試圖為SWIFT中的使用找出一個合適的單例模型。到目前為止,我已經能夠得到一個非線程安全模型,其作用是:class var sharedInstance:TPScopeManager {     get {         struct Static {             static var instance : TPScopeManager? = nil         }         if !Static.instance {             Static.instance = TPScopeManager()         }         return Static.instance!     }}將單例實例封裝在靜態結構中應該允許單個實例在沒有復雜命名方案的情況下不會與單例實例發生沖突,并且應該使事情變得相當私密。但是很明顯,這個模型并不是線程安全的,所以我嘗試在整個過程中添加調度_ONE:class var sharedInstance:TPScopeManager {     get {         struct Static {             static var instance : TPScopeManager? = nil             static var token : dispatch_once_t = 0         }         dispatch_once(Static.token) { Static.instance = TPScopeManager() }         return Static.instance!     }}但是,我在dispatch_once行:無法將表達式的類型“void”轉換為“()”類型我嘗試過幾個不同的語法變體,但它們似乎都有相同的結果:dispatch_once(Static.token, { Static.instance = TPScopeManager() })什么是正確的用法?dispatch_once用斯威夫特?我最初認為問題是由于()在錯誤消息中,但是我越看它,我就越認為這可能是一個獲得dispatch_once_t正確定義。
查看完整描述

3 回答

?
梵蒂岡之花

TA貢獻1900條經驗 獲得超5個贊

TL;DR:使用類常數如果您正在使用SWIFT1.2或更高版本,并且嵌套結構如果需要支持早期版本,請使用此方法。

根據我使用SWIFT的經驗,有三種方法可以實現Singleton模式,它們支持延遲初始化和線程安全。

類常數

class?Singleton??{
???static?let?sharedInstance?=?Singleton()}

此方法支持延遲初始化,因為Swift延遲初始化類常量(和變量),并且通過let..

SWIFT 1.2中引入了類常數。如果需要支持SWIFT的早期版本,請使用下面的嵌套結構方法或全局常量。

嵌套結構

class?Singleton?{
????class?var?sharedInstance:?Singleton?{
????????struct?Static?{
????????????static?let?instance:?Singleton?=?Singleton()
????????}
????????return?Static.instance????}}

這里我們使用嵌套結構的靜態常數作為類常量。這是SWIFT1.1及更早版本中缺少靜態類常量的一種解決方法,并且仍然可以解決函數中缺少靜態常量和變量的問題。

派遣一次

傳統的目標-C方法移植到SWIFT。我相當肯定,與嵌套的struct方法相比沒有什么優勢,但我還是把它放在這里,因為我發現語法上的差異很有趣。

class?Singleton?{
????class?var?sharedInstance:?Singleton?{
????????struct?Static?{
????????????static?var?onceToken:?dispatch_once_t?=?0
????????????static?var?instance:?Singleton??=?nil
????????}
????????dispatch_once(&Static.onceToken)?{
????????????Static.instance?=?Singleton()
????????}
????????return?Static.instance!
????}}


查看完整回答
反對 回復 2019-06-03
?
白衣非少年

TA貢獻1155條經驗 獲得超0個贊

由于Apple現在已經澄清靜態struct變量被初始化為延遲并被包裝在調度_ONE中(請參閱文章末尾的注釋),我認為我的最后解決方案將是:

class?WithSingleton?{
????class?var?sharedInstance?:WithSingleton?{
????????struct?Singleton?{
????????????static?let?instance?=?WithSingleton()
????????}

????????return?Singleton.instance????}}

這利用了靜態結構元素的自動延遲、線程安全初始化,向使用者安全地隱藏了實際實現,使所有內容保持緊湊的可讀性,并消除了一個可見的全局變量。

蘋果已經澄清,延遲初始化程序是線程安全的,因此不需要dispatch_once或類似的保護

全局變量的延遲初始化器(也適用于結構和枚舉的靜態成員)將在第一次訪問全局變量時運行,并以調度_ONE的形式啟動,以確保初始化是原子的。這使得在代碼中使用調度一次的方法很酷:只需使用初始化器聲明一個全局變量,并將其標記為私有變量即可。


查看完整回答
反對 回復 2019-06-03
  • 3 回答
  • 0 關注
  • 708 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號