我已经看过了苹果“的PageControl”样本项目(See here),我看到这个代码功能:苹果示例代码中的错误代码?
- (void)loadScrollViewWithPage:(int)page
{
if (page < 0)
return;
if (page >= kNumberOfPages)
return;
// replace the placeholder if necessary
MyViewController *controller = [viewControllers objectAtIndex:page];
if ((NSNull *)controller == [NSNull null])
{
controller = [[MyViewController alloc] initWithPageNumber:page];
[viewControllers replaceObjectAtIndex:page withObject:controller];
[controller release];
}
// add the controller's view to the scroll view
if (controller.view.superview == nil)
{
CGRect frame = scrollView.frame;
frame.origin.x = frame.size.width * page;
frame.origin.y = 0;
controller.view.frame = frame;
[scrollView addSubview:controller.view];
NSDictionary *numberItem = [self.contentList objectAtIndex:page];
controller.numberImage.image = [UIImage imageNamed:[numberItem valueForKey:ImageKey]];
controller.numberTitle.text = [numberItem valueForKey:NameKey];
}
}
也有一些是我不明白。
如果测试部分if ((NSNull *)controller == [NSNull null])
是真的,那么我们有
controller = [[MyViewController alloc] initWithPageNumber:page];
[viewControllers replaceObjectAtIndex:page withObject:controller];
[controller release];
然后刚过:
if (controller.view.superview == nil)
但是,控制器刚刚被释放。我认为它可能会工作,因为控制器仍然在记忆中,但这不是编码这些东西的错误方式吗?
+1使用autorelease的想法。就目前而言,代码不仅依赖于NSArray保留添加到其中的对象的事实(正如您所说,这很常见),而且还取决于其他线程是否从NSArray中删除对象。 (不可否认,因为这些是UI对象,这不太可能发生,但继续使用不保留的对象仍然是业障。) – 2011-03-19 01:33:08