关于 @synchronized(self) 的理解

本文探讨了Objective-C中单例模式的实现方式,特别是如何通过静态方法和@synchronized确保单例对象的唯一性和线程安全性。文章解释了即便在单例尚未创建时,也能使用@synchronized(self)进行同步控制的原因。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

转自 :  http://www.devdiv.com/forum.php?mod=viewthread&tid=121163


+ (IPTVMsgCenter *)shareInstance
{
        @synchronized(self)
        {
                if (!g_instance) {
                        g_instance = [[IPTVMsgCenter alloc] init];
                }
        }
        return g_instance;
}

在单例中都有上面的一个函数,我想问一下为什么这时候这个单例还没有创建就可以用@synchronized(self)呢?




@synchronized()的参数是作为标示,如果我写个MyLock传入也是可以的,这里self也是个标示,你的疑惑是self明明没有实例,传入有什么用?你忽略了个细节,你看看这个是什么方法,静态方法,OBjective-C语言是运行时检测,所以在调用过程中,静态方法的self等于[IPTVMsgCenter Class];所以这样写
@synchronized([IPTVMsgCenter Class]){}也是可以的,这下懂了吧





你自己做个测试,在静态方法中看下if(self == [Class clas])是否成立






评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值