NSRangeException随机崩溃应用程序

时间:2013-04-06 12:43:47

标签: iphone ios xml nsrangeexception

  1. 我的应用程序在_storeArray
  2. 中进行了ramdomly崩溃
  3. 在viewDidLoad中,有一个解析xml文件的方法[self loadUrl],然后添加字典[_storeArray addObject:dictionary];
  4. 当轮播重新使用View首先调用[self loadUrl]时,崩溃就会发生。
  5. 我添加了if(_storeArray),但它仍然崩溃。
  6. 这是一个例外:

    2013-04-06 09:33:35.254 Semhora[7347:907] *** Terminating app due to uncaught exception 'NSRangeException', reason: '*** -[__NSArrayM objectAtIndex:]: index 0 beyond bounds for empty array'
    

    这是代码:

    - (void)loadURL:(NSString *)newURL{
    
        // Create a success block to be called when the asyn request completes
        TBXMLSuccessBlock successBlock = ^(TBXML *tbxmlDocument) {
    
    
            [[UIApplication sharedApplication] setNetworkActivityIndicatorVisible:NO];
            // If TBXML found a root node, process element and iterate all children
            if (tbxmlDocument.rootXMLElement)
            {
                // Obtain root element
                TBXMLElement * root = tbxml.rootXMLElement;
                if (root)
                {
                    [_storeArray removeAllObjects];
                    TBXMLElement * elem_PLANT = [TBXML childElementNamed:@"principal" parentElement:root];
                    while (elem_PLANT !=nil)
                    {
                        TBXMLElement * elem_title = [TBXML childElementNamed:@"title" parentElement:elem_PLANT];
                        NSString *titleName = [TBXML textForElement:elem_title];
    
    //                    TBXMLElement * elem_artist = [TBXML childElementNamed:@"text" parentElement:elem_PLANT];
    //                    NSString *artistName = [TBXML textForElement:elem_artist];
    
                        TBXMLElement * elem_thumb = [TBXML childElementNamed:@"thumb_url" parentElement:elem_PLANT];
                        NSString *thumbName = [TBXML textForElement:elem_thumb];
    
                        TBXMLElement * elem_photo1 = [TBXML childElementNamed:@"photo1" parentElement:elem_PLANT];
                        NSString *photo1Name = [TBXML textForElement:elem_photo1];
    
                        TBXMLElement * elem_photo2 = [TBXML childElementNamed:@"photo2" parentElement:elem_PLANT];
                        NSString *photo2Name = [TBXML textForElement:elem_photo2];
    
                        TBXMLElement * elem_photo3 = [TBXML childElementNamed:@"photo3" parentElement:elem_PLANT];
                        NSString *photo3Name = [TBXML textForElement:elem_photo3];
    
                        TBXMLElement * elem_photo4 = [TBXML childElementNamed:@"photo4" parentElement:elem_PLANT];
                        NSString *photo4Name = [TBXML textForElement:elem_photo4];
    
                        TBXMLElement * elem_photo5 = [TBXML childElementNamed:@"photo5" parentElement:elem_PLANT];
                        NSString *photo5Name = [TBXML textForElement:elem_photo5];
    
                        NSDictionary *dictionary = [[NSDictionary alloc]initWithObjects:@[titleName, thumbName, photo1Name, photo2Name, photo3Name, photo4Name, photo5Name] forKeys:@[@"title", @"thumb_url", @"photo1", @"photo2", @"photo3", @"photo4", @"photo5",]];
                        elem_PLANT = [TBXML nextSiblingNamed:@"principal" searchFromElement:elem_PLANT];
                        [_storeArray addObject:dictionary];
                       [self startLoading:dictionary];
                         [[NSOperationQueue mainQueue] addOperationWithBlock:^{ [_carousel reloadData]; }];
                    }
    
    
                }
    
            }
    
        };
    
        // Create a failure block that gets called if something goes wrong
        TBXMLFailureBlock failureBlock = ^(TBXML *tbxmlDocument, NSError * error) {
            NSLog(@"Error! %@ %@", [error localizedDescription], [error userInfo]);
        };
    
        // Initialize TBXML with the URL of an XML doc. TBXML asynchronously loads and parses the file.
        tbxml = [[TBXML alloc] initWithURL:[NSURL URLWithString:newURL]
                                   success:successBlock
                                   failure:failureBlock];
    
    }
    
    - (UIView *)carousel:(iCarousel *)carousel viewForItemAtIndex:(NSUInteger)index reusingView:(UIView *)view
    {
        //create new view if no view is available for recycling
        if (view == nil)
        {
            FXImageView *imageView = [[FXImageView alloc] initWithFrame:CGRectMake(0, 0, 200.0f, 200.0f)];
            imageView.contentMode = UIViewContentModeScaleAspectFit;
            imageView.asynchronous = YES;
            imageView.reflectionScale = 0.5f;
            imageView.reflectionAlpha = 0.25f;
            imageView.reflectionGap = 10.0f;
            imageView.shadowOffset = CGSizeMake(0.0f, 2.0f);
            imageView.shadowBlur = 5.0f;
            imageView.cornerRadius = 10.0f;
            view = imageView;
        }
    
        //show placeholder
        ((FXImageView *)view).processedImage = [UIImage imageNamed:@"placeholder.png"];
    
        //set image
    
        NSLog(@"%@", _storeArray);
        if (_storeArray) {
    
            NSDictionary *tempdic = [_storeArray objectAtIndex:0];
    
            switch (index) {
                case 0:
                    [(FXImageView *)view setImageWithContentsOfURL:[NSURL URLWithString:[tempdic objectForKey:@"photo1"]]];
                    break;
                case 1:
                    [(FXImageView *)view setImageWithContentsOfURL:[NSURL URLWithString:[tempdic objectForKey:@"photo2"]]];
                    break;
                case 2:
                    [(FXImageView *)view setImageWithContentsOfURL:[NSURL URLWithString:[tempdic objectForKey:@"photo3"]]];
                    break;
                case 3:
                   [(FXImageView *)view setImageWithContentsOfURL:[NSURL URLWithString:[tempdic objectForKey:@"photo4"]]];
                    break;
                case 4:
                    [(FXImageView *)view setImageWithContentsOfURL:[NSURL URLWithString:[tempdic objectForKey:@"photo5"]]];
                    break;
                default:
                    break;
            }
        }
    
        return view;
    }
    

2 个答案:

答案 0 :(得分:1)

  1. _storeArray的当前检查仅检查变量是否存在,但是如果其中确实存在任何元素则不存在。但是在检查之后你只是假设数组中有1个元素而不检查它是否为真。

    所以改变这个

    if (_storeArray) {
    

    到此:

    if (_storeArray && [_storeArray count] > 0) {
    
  2. 此外,您假设字典将具有photo1等的密钥。但如果不是,则生成的URL将为空,因此视图也可能获得nil URL。 / p>

    我会改变如下:

    NSDictionary *tempdic = [_storeArray objectAtIndex:0];
    NSString *tempObjKey = nil;
    
    switch (index) {
        case 0:
            tempObjKey = @"photo1";
            break;
        case 1:
            tempObjKey = @"photo2";
            break;
        case 2:
            tempObjKey = @"photo3";
            break;
        case 3:
            tempObjKey = @"photo4";
            break;
        case 4:
            tempObjKey = @"photo5";
            break;
        default:
            break;
    }
    
    if (tempObjKey && [tempdic objectForKey:tempObjKey])
        [(FXImageView *)view setImageWithContentsOfURL:[NSURL URLWithString:[tempdic objectForKey:tempObjKey]]];
    }
    

答案 1 :(得分:0)

我需要知道一件事,你的解析是否在所有这些之前发生并成功返回一个数组(NSLog),因为这里的数组似乎是个问题。你不能直接取出第一个物体,你必须保持防守,所以做这样的事情。

 if (_storeArray) {

    if(_storeArray.count >0) {

    NSDictionary *tempdic = [_storeArray objectAtIndex:0];

    switch (index) { // all ur stmts }
    }}