OStack程序员社区-中国程序员成长平台

标题: ios - ARC 正在释放 calloc'ed 内存? [打印本页]

作者: 菜鸟教程小白    时间: 2022-12-13 17:08
标题: ios - ARC 正在释放 calloc'ed 内存?

我的代码中发生了一些奇怪的事情。基本上我正在做网络流应用程序,将一些数据传输到 iOS 上的环形缓冲区内存中,然后读取内存。 在一些不确定的数据量之后,我得到了 EXC_BAD_ACCESS。所以我启用了 NSZombieEnabledNSAutoreleaseFreedObjectCheckEnabled 并设置了 malloc_error_break 并且能够查明错误的原因。

我的 MainClass 具有该属性(也尝试过强引用,相同的行为)

@property (nonatomic, retain) RingBuffer *readBuffer;

RingBuffer 类中,我将缓冲区大小初始化为:

-(id) initWithSize: (NSInteger) size
{
    self = [super init];
    m_size = size;
    buffer = (unsigned char *)calloc(m_size, sizeof(unsigned char));
    overflow = FALSE;
    m_tail = 0;
    m_head = 0;
    error = 0;
    return self;
}

之后,我使用 push 方法在 ringbuffer 中插入数据

- (void) push: (unsigned char) byte
{
    if (m_head == m_size && overflow == FALSE) {
        m_head = 0;
        overflow = TRUE;
        }
    buffer[m_head] = byte;
    m_head ++;
    if (overflow) m_tail++;
    if (m_tail == m_size) m_tail = 0;
}

如果我删除推送调用,应用程序不会崩溃。如果调用推送调用,它会在一段时间后崩溃。有时我得到 alloc: *** error for object 0x1cad3404: wrong checksum for freed object - object 可能在被释放后被修改。 *** 在 malloc_error_break 中设置断点进行调试...有时只是 EXC_BAD_ACCESS。

基本上,我不明白为什么会导致这个问题? ARC是否有可能释放了calloced内存?



Best Answer-推荐答案


Is it possible that ARC released the calloced memory ?

不,这是不可能的。 ARC 是 Automatic Reference Counting 的缩写,是一种编译器功能,如果启用,它会通过将释放、保留和自动释放内存调用直接插入到编译代码中来提供 Objective C 对象的自动内存管理。由于 buffer 不是 Objective C 对象,而是指向堆上已分配内存块的指针,ARC 不会释放该内存块。您有义务自己释放这 block 已分配的内存。

要详细了解 ARC 的工作原理,请观看 Apple 的 WWDC 2011 session 视频:Introducing Automatic Reference Counting .

Basically, what i don't understand is why is this causing the issue ?

很难说,但问题可能是 m_head 仅在 m_head == size && overflow == FALSE 时设置为零。此条件仅在第一次 m_head 等于 m_size 时为真,(因为溢出 == FALSE),但在下一次 m_head 时不再为真> 等于 m_size,因为 overflow 等于 TRUE(并且 m_head 不会重置为 0)。

关于ios - ARC 正在释放 calloc'ed 内存?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12902778/






欢迎光临 OStack程序员社区-中国程序员成长平台 (https://ostack.cn/) Powered by Discuz! X3.4