Сбой KVO / KVC при перезагрузке ранее выгруженных пакетов - PullRequest
2 голосов
/ 11 февраля 2012

У меня проблема с загружаемыми пакетами и KVO. Кажется, что любой класс, к которому подключены наблюдатели KVO, не может быть безопасно выгружен с помощью метода -unload NSBundle.

Я делаю следующее:

for (int i = 0; i < 100; i++)
{
    [bundle load];

    Class bundleClass = [bundle principalClass];

    [[[bundleClass alloc] init] release];

    [bundle unload];
}

И в методе класса пучка -init метод,

    [self addObserver: self 
           forKeyPath: @"name"
              options: 0
              context: nil];

    self.name = @"jim";

Цикл проходит через ряд итераций, иногда сбои во втором раунде, иногда на тридцатом.

Он всегда вылетает с этой обратной трассировкой, с сигналом EXC_BAD_ACCESS.

#0  0x00007fff8a30deab in objc_msgSend ()
#1  0x00007fff8609d862 in NSKeyValueNotifyObserver ()
#2  0x00007fff860be99b in NSKeyValueDidChange ()
#3  0x00007fff8606b0fb in -[NSObject(NSKeyValueObserverNotification) didChangeValueForKey:] ()
#4  0x00000001007a4c2c in -[Bundle init] (self=0x101902130, _cmd=0x7fff8ea369b0) at /Users/joerick/Desktop/bundleTest/testbundle/Bundle.m:26
#5  0x0000000100001731 in -[SIAppDelegate applicationDidFinishLaunching:] (self=0x100326a90, _cmd=0x7fff876e285f, aNotification=0x100131ea0) at /Users/joerick/Desktop/bundleTest/bundleTest/SIAppDelegate.m:28
#6  0x00007fff8606ade2 in __-[NSNotificationCenter addObserver:selector:name:object:]_block_invoke_1 ()
#7  0x00007fff8b470e0a in _CFXNotificationPost ()
#8  0x00007fff86057097 in -[NSNotificationCenter postNotificationName:object:userInfo:] ()
#9  0x00007fff8e1bbaa7 in -[NSApplication _postDidFinishNotification] ()
#10 0x00007fff8e1bb80d in -[NSApplication _sendFinishLaunchingNotification] ()
....

Полный код здесь

Вы можете скачать пример проекта, показывающего эту проблему здесь .

Я думаю, что это ошибка в Какао, но мне интересно, если кто-нибудь мог увидеть, что я делаю что-то глупое?

1 Ответ

1 голос
/ 19 марта 2012

Я сообщил об этом в Apple.

rdar: // 11017946

...