我正在使用自定义委托对象在请求完成后执行一些清理任务。 ASIHTTPRequest不保留代理,因此我无法自动发布它们。现在,这就是我分配和释放代表的方式。
MyDelegate *delegate = [[MyDelegate alloc] init];
ASIHTTPRequest *request = [ASIHTTPRequest requestWithURL:url];
[request setDelegate:delegate];
- (void)requestFinished:(ASIHTTPRequest *)request
{
[self release];
}
- (void)requestFailed:(ASIHTTPRequest *)request
{
[self release];
}
有更好的方法吗?让代表们发布自己看起来很难看,Xcode的构建和分析让我感到不舒服。
答案 0 :(得分:4)
为什么你有一个单独的类纯粹是一个委托?这不是委托对象通常的工作方式。通常,创建ASIHTTPRequest的控制器成为委托,此时您不必担心释放它,因为它已经比ASIHTTPRequest更长(并且如果您的控制器在ASIHTTPRequest完成之前被解除分配,则需要取消请求)。
答案 1 :(得分:4)
一种简单的方法是为主控制器中的每个活动请求维护一组可变的委托(在这种情况下为app委托):
@interface MyAppController
{
NSMutableSet * activeDelegates;
}
@end
@implementation MyAppController
- (id)init
{
if ((self = [super init]) == nil) { return nil; }
activeDelegates = [[NSMutableSet alloc] initWithCapacity:0];
return self;
}
- (void)dealloc
{
[activeDelegates release];
}
- (void)createRequest
{
MyDelegate *delegate = [[MyDelegate alloc] init];
[activeDelegates addObject:delegate];
[delegate release];
ASIHTTPRequest *request = [ASIHTTPRequest requestWithURL:url];
[request setDelegate:self];
...
}
- (void)requestFinished:(ASIHTTPRequest *)request
{
MyDelegate *delegate = [request delegate];
[delegate doSomething];
[activeDelegates removeObject:delegate];
{
- (void)requestFailed:(ASIHTTPRequest *)request
{
[activeDelegates removeObject:[request delegate]];
}
@end
答案 2 :(得分:0)
如果您不想为所有委托实例创建“控制器”类,我仍然至少遵循内存约定规则,并在将其设置为asihhtprequest后立即释放该委托。然后我会在委托中包含一个属性,名称为manageItsOwnLifetime(BOOL),并将此设置为YES我会做[自我保留] ......