在Block中使用weakSelf与strongSelf的意义

本文探讨在Objective-C的Block中使用弱引用(weakSelf)与强引用(strongSelf)的目的与意义,通过实例对比说明二者结合使用可以有效避免循环引用问题,并确保正确输出预期值。

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

在Block中使用weakSelf与strongSelf的意义

我们都会声明一个弱引用在block中使用, 目的就是防止循环引用,  那么weakSelfstrongSelf一起使用目的是什么呢? 首先先定义2个宏:

#define YXWeakSelf(type)  __weak typeof(type) weak##type = type;
#define StrongSelf(type)  __strong typeof(type) type = weak##type;

在Controller中YXWeakSelf(self)YXStrongSelf(self)一起使用情况很多,为了防止循环引用,还是不懂原因的见如下实例:

我们创建一个shop并且在shop.myBlock代码块中使用弱引用YXWeakSelf(shop)

    LRShop *shop = [[LRShop alloc]init];
    shop.string = @"welcome to our company";
    //弱引用
    YXWeakSelf(shop)
    shop.myBlock = ^{
        NSLog(@"%@",weakshop.string);
    };
    shop.myBlock();

YXWeakSelf(shop)YXStrongSelf(shop)一起使用

LRShop *shop = [[LRShop alloc]init];
    shop.string = @"welcome to our company";
    //弱引用
    YXWeakSelf(shop);
    shop.myBlock = ^{
        //强引用
        YXStrongSelf(shop)
        NSLog(@"%@",shop.string);
    };
    shop.myBlock();

这2个打印结果都是shop.string有值并且shop也销毁了, 看起来是没什么区别:


仅仅使用YXWeakSelf(shop)并且在myBlock中增加一个延迟3秒在输出就会出现问题, 虽然对象销毁了, 输出的值却是null

//弱引用
 YXWeakSelf(shop);
    shop.myBlock = ^{
        dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(3.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
            NSLog(@"%@",weakshop.string);
        });
    };
    shop.myBlock();

如果YXWeakSelf(shop)YXStrongSelf(shop)一起使用输出的shop.string有值,对象也销毁了, 我就不再截图给大家看了!

//弱引用
 YXWeakSelf(shop)
    shop.myBlock = ^{
        //强引用
        YXStrongSelf(shop)
        dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(3.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
            NSLog(@"%@",shop.string);
        });
    };
    shop.myBlock();

通过上面一堆的解释, 我们明显发现YXWeakSelf(shop)YXStrongSelf(shop)一起使用的好处, 不但能打印出我想要的值,而且也不会造成循环引用 , 在开发中这两个方法可以根据实际情况进行使用!


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yusirxiaer

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值