2

我正在为我的应用程序构建可插拔接口。我坚持使用插件的更新机制。

这是让我感到困惑的代码。

- (void) unloadBundle{
    [_pluginInstance release], _pluginInstance = nil;
    [[self bundle] unload];
    [_bundle release], _bundle = nil;
}

- (void) loadBundleWithURL:(NSURL *)bundleURL{
    NSBundle *newBundle = [NSBundle bundleWithURL:bundleURL];
    if (newBundle){
        [self setBundle:newBundle];
        [self setPluginInstance:[[[[self.bundle principalClass] alloc] init] autorelease]];

        NSLog(@"New bundle: %@", self.bundle);
        NSLog(@"New bundle's principal class %@", [self.bundle principalClass]);
        NSLog(@"Principal class' bundle is %@", [NSBundle bundleForClass:[self.bundle principalClass]]);
        NSLog(@"Plugin's class %@", [self.pluginInstance class]);
    }
}

这些是我的插件主体类包装器的方法。我只是调用unloadBundle,然后loadBundleWithURL使用新版本捆绑包的 URL。执行时,它将以下内容记录到控制台中:

New bundle: NSBundle </Users/prudnikov/Work/Projects/***/Name.pluginextension> (loaded)
New bundle's principal class MyPluginClass
Principal class' bundle is NSBundle </Users/prudnikov/Library/Application Support/MyApp/PlugIns/Name.pluginextension> (not yet loaded)
Plugin's class MyPluginClass

意味着我从新捆绑包中获取主体类,获取它的捆绑包[NSBundle bundleForClass:]并且它是旧捆绑包。

任何想法我做错了什么?

4

1 回答 1

2

这种情况下的问题是我忘记在不同的地方卸载捆绑包。我有一种方法可以验证该包是一个有效的插件包。

调用principalClass会自动加载包。所以,需要调用unload

于 2012-12-18T19:00:41.120 回答