2

在我的应用程序中,我尝试从 url 加载内容,将它们存储在可变数组中并在表格视图中显示它们。但我无法让它工作,因为每次我运行应用程序时都会出现这个错误:

*** Terminating app due to uncaught exception 'NSRangeException', 
reason: '*** -[__NSArrayI objectAtIndex:]: index 1 beyond bounds [0 .. 0]'
*** First throw call stack:
(0x34dd088f 0x36d9e259 0x34d2823d 0x316e562f 0x315f09a9 0x313c0c5d 0x313c1b95 0x313c1ae7
 0x313c16c3 0xa5cfb 0x33623ec7 0x35387a09 0x35390051 0x33622965 0xa4dc1 0x313a8e33 
 0x313cd629 0x31391d7d 0x314544dd 0x3139a55d 0x3139a579 0x3139a40b 0x3139a3e7 0x313a8015 
 0x313a1985 0x3136fc6b 0x3136f70f 0x3136f0e3 0x3439222b 0x34da4523 0x34da44c5 0x34da3313 
 0x34d264a5 0x34d2636d 0x313a0a13 0x3139de7d 0xa4745 0xa46dc)
terminate called throwing an exception

我创建了应该在我的 viewDidLoad 中填充表的数组:

_videos = [[NSMutableArray alloc] init];

然后我连接到 url 并解析接收到的 xml 数据。这就像它应该的那样工作。当打开某个标签时,我创建了我的视频对象,并在用数据填充它们后,我将这些对象添加到我的数组中:

[_videos addObject:currentVideo];

这似乎也有效,因为它返回正确数量的视频

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {

    return _videos.count;
}

叫做。但在此之后,应用程序崩溃了,我什至没有达到尝试填充表格视图的地步。该函数如下所示:

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath {

    Video *curVideo = [_videos objectAtIndex:indexPath.row];

    static NSString *CellIdentifier = @"CustomCell";

    CustomCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];

    if (cell == nil)        
        cell = [[CustomCell alloc] initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:CellIdentifier];

    cell.titleLabel.text = [curVideo title];
    cell.descLabel.text = [curVideo desc];

    return cell;
}

做错了什么?

提前致谢

4

3 回答 3

5

-[__NSArrayI objectAtIndex:]: index 4 beyond bounds [0 .. 1]'当我试图展示一个模态故事板时,我有相同的错误签名,表格视图有两个(从五个更新)静态表格单元格部分。直到我删除了视图中不再需要的三个表格单元格部分后,才出现此错误。在详细检查了模态演示之前的所有 objectAtIndex 引用两天后,我决定查看 UITableViewController 子类代码本身。我找到了这个:

- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
{
//#warning Potentially incomplete method implementation.
    // Return the number of sections.
    return 5;
}

然后灯泡熄灭了。被引用的index 4部分与我的表格视图部分的数量和[0 .. 1]引用我当前的两个表格单元部分的边界有关。更新该return值以匹配 Storyboard 表格视图中当前表格单元格部分的数量解决了该问题。

于 2013-07-03T22:56:01.423 回答
4

您可能_videos在初始化之前访问的某个地方。很可能您会在 之后init,但在加载视图之前执行此操作。解决此类问题的方法是独占使用访问器,并延迟初始化self.videos。这是从不直接访问您的 ivars 的众多原因之一,除了 ininitdealloc.

@interface ...
@property (nonatomic, readonly, strong) NSMutableArray *videos;
@end

@implementation ...
{
  NSMutableArray *_videos; // Can't auto-synthesize. We override the only accessor.
}

- (NSMutableArray *)videos {
   if (! _videos) {
     _videos = [NSMutableArray new];
   }
   return _videos;
}

self.videos现在,无论何时发生,所有对的引用都将被初始化。

您还可以在 中正确初始化视频init,这需要更少的代码:

@interface ...
@property (nonatomic, readonly, strong) NSMutableArray *videos;
@end

@implementation ...

- (id)init {
   self = [super init];
   if (self) {
     _videos = [NSMutableArray new];
   }
   return self;
}
于 2012-09-28T13:41:44.587 回答
0

我已经为这样的图像数组传递了虚拟图像名称,

arrImages = [NSArray arrayWithObjects:[UIImage imageNamed:@"some.png"]

上面的行引起了我的错误。所以我用@“category.png”之类的现有图像更改了@“some.png”。

这对我有用。确保您从包中传递了正确的图像名称。

于 2015-06-18T13:06:23.687 回答