# import "NetworkManager.h"
static NetworkManager *network = nil;
@implementation NetworkManager
+ (NetworkManager *)getNetworkInstance{
@synchronized(self){
if (nil == network){
network = [[NetworkManager alloc] init];
{
}
return network;
}
英文文档:
Using the @synchronized Directive(指令)
The @synchronized directive is a convenient way to create mutex locks(互斥锁) on the flyin Objective-C code. The @synchronized directive does what any other mutex lock woulddo—it prevents(预防) different threads from acquiring the same lock at the same time. Inthis case, however, you do not have to create the mutex or lock object directly. Instead,you simply use any Objective-C object as a lock token with @synchronized。
The object passed to the @synchronized directive is a unique identifier used to distinguish theprotected block. If you execute the preceding method in two different threads, passing a differentobject for the anObj parameter on each thread, each would take its lock and continue processing without being blocked by the other. If you pass the same object in both cases, however, one of the threads would acquire the lock first and the other would block until the first thread completed the critical section.
As a precautionary measure, the @synchronized block implicitly adds an exception handler to theprotected code. This handler automatically releases the mutex in the event that an exception isthrown. This means that in order to use the @synchronized directive, you must also enableObjective-C exception handling in your code. If you do not want the additional overhead caused bythe implicit exception handler, you should consider using the lock classes.
For more information about the @synchronized directive, see The Objective-C ProgrammingLanguage.
关于@synchronized(self)的用法
最新推荐文章于 2023-08-29 16:31:59 发布