एआरसी के तहत सिंगलटन के साझा इंस्टेंस एक्सेसर में dispatch_once का उपयोग करने का सटीक कारण क्या है?ऐप्पल एआरसी के तहत सिंगलटन पैटर्न को लागू करने के लिए dispatch_once का उपयोग करने की सलाह क्यों देता है?
+ (MyClass *)sharedInstance
{
// Static local predicate must be initialized to 0
static MyClass *sharedInstance = nil;
static dispatch_once_t onceToken = 0;
dispatch_once(&onceToken, ^{
sharedInstance = [[MyClass alloc] init];
// Do any other initialisation stuff here
});
return sharedInstance;
}
क्या पृष्ठभूमि में सिंगलटन को असीमित रूप से तुरंत चालू करना बुरा विचार नहीं है? मेरा मतलब है कि क्या होता है यदि मैं उस साझा उदाहरण का अनुरोध करता हूं और तुरंत उस पर भरोसा करता हूं, लेकिन प्रेषण तक मेरी वस्तु बनाने के लिए प्रेषण लेता है? यह तुरंत वापस नहीं आता है? कम से कम ऐसा लगता है कि ग्रैंड सेंट्रल डिस्पैच का पूरा बिंदु है।
तो वे ऐसा क्यों कर रहे हैं?
'नोट: स्थिर और वैश्विक चर शून्य पर डिफ़ॉल्ट हैं। – ikkentim