gpt4 book ai didi

objective-c - 避免从并发使用的访问器中获取已释放的对象

转载 作者:塔克拉玛干 更新时间:2023-11-02 09:50:47 27 4
gpt4 key购买 nike

在我的多线程应用程序中,有一个属性可以被多个线程并发访问。该属性定义为 @property (retain) NSObject *status

如何以原子方式获取和保留该属性,以便我可以在我的本地范围内安全地使用它?存储和检索此类值的最佳做法是什么?

NSObject *status = [self status];
[... do some processing on status ...]

// But: I cannot rely on the object assigned to my status variable
// still being valid, since another thread might have used my
// [self setStatus] accessor, implicitly calling a release on the old object,
// releasing it under my feet.
// Not even NSObject *status = [[self status] retain]; would fix that.

最佳答案

In my multithreaded application, there is a property that can be accessed concurrently by multiple threads. The property is defined as @property (retain) NSObject *status.

atomic 是默认值 - 不需要关键字或说明符。

How do I atomically get and retain the property, so I can safely use it in my local scope?

因为它是atomicretained、readwrite@synthesized,所以您可以随时使用访问器.如果您直接在初始化器中访问 ivar 并且仅在 dealloc 中使用访问器,并且在其他任何地方都使用访问器,那么就您所询问的方面而言,这将是安全的。返回值为retain+autoreleased。由于它是自动释放的,该对象将继续存在——至少直到本地线程上的顶部自动释放池被弹出。

我上次单步执行时,它看起来像这样(简单形式):

- (NSObject *)object
{
enter_object_level_spin_lock();
id ret = [[object retain] autorelease];
exit_object_level_spin_lock();
return ret;
}

尽管我不记得 autorelease 是否在锁中(理想情况下它会在外面以缩短锁定时间)。

What is the best practice to store and retrieve such a value?

原子属性对并发或线程安全的作用很小——不要将它们视为适当线程安全的替代品。原子属性访问器提供的线程安全性也很不寻常。通常,对于适当的并发程序,您需要的不仅仅是一个原子。我很少使用原子属性,并制作一些疯狂的并发程序。如果您需要高性能/事务并发,您将需要知道如何有效地使用锁。当然,也有很多方法可以避免并发设计。我的自动解决方案涉及自己处理锁定。

关于objective-c - 避免从并发使用的访问器中获取已释放的对象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9080621/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com