DEEPAK kumar
DEEPAK kumar

Reputation: 27

NSArrayM objectAtIndex: index 6 beyond bounds

I am developing iOS application. Value store on Array, but when I run app, its crashes with array index out of bounds. Please Help and Thanks in advance..

Code:

daysOfWeek = [NSArray arrayWithObjects:@"Monday",@"Tuesday",@"Wednesday",@"Thursday",@"Friday",@"Saturday",@"Sunday", nil];
    for (int i = 0; i<= [_daysOfWeek count]; i++) {
   _mondayView=[[UIView alloc]initWithFrame:CGRectMake(45, 300  , 830, 30.0)];
         [_mondayView setBackgroundColor:[UIColor colorWithRed:190.0/255.0 green:190.0/255.0 blue:194.0/255.0 alpha:1.0]];
        [_weeklyView addSubview:_mondayView];

        UILabel *daysLabel = [[UILabel alloc]initWithFrame:CGRectMake(65.0f, 300.0f, 120.0f, 30.0f)];
        daysLabel.backgroundColor = [UIColor blueColor];
        daysLabel.text = [NSString stringWithFormat:@"%@",[_daysOfWeek objectAtIndex:i]];
        [_weeklyView addSubview:daysLabel];

    }

Crash Log:

2016-11-14 11:48:41.266 FH Harvey[1839:67640] *** Terminating app due to uncaught exception 'NSRangeException', reason: '*** -[__NSArrayI objectAtIndex:]: index 7 beyond bounds [0 .. 6]'
*** First throw call stack:
(
    0   CoreFoundation                      0x000000011101934b __exceptionPreprocess + 171
    1   libobjc.A.dylib                     0x000000011065d21e objc_exception_throw + 48
    2   CoreFoundation                      0x0000000110f53eeb -[__NSArrayI objectAtIndex:] + 155
    3   FH Harvey                           0x000000010fe1ee62 -[FHWeeklyViewController viewDidLoad] + 1026
    4   UIKit                               0x00000001115ddc99 -[UIViewController loadViewIfRequired] + 1258
    5   UIKit                               0x00000001115e4102 -[UIViewController __viewWillAppear:] + 118
    6   UIKit                               0x000000011160efbf -[UINavigationController _startCustomTransition:] + 1290
    7   UIKit                               0x000000011161fc34 -[UINavigationController _startDeferredTransitionIfNeeded:] + 697
    8   UIKit                               0x0000000111620dc7 -[UINavigationController __viewWillLayoutSubviews] + 58
    9   UIKit                               0x0000000111817d6f -[UILayoutContainerView layoutSubviews] + 223
    10  UIKit                               0x0000000111500f50 -[UIView(CALayerDelegate) layoutSublayersOfLayer:] + 1237
    11  QuartzCore                          0x000000010ffbdcc4 -[CALayer layoutSublayers] + 146
    12  QuartzCore                          0x000000010ffb1788 _ZN2CA5Layer16layout_if_neededEPNS_11TransactionE + 366
    13  QuartzCore                          0x000000010ffb1606 _ZN2CA5Layer28layout_and_display_if_neededEPNS_11TransactionE + 24
    14  QuartzCore                          0x000000010ff3f680 _ZN2CA7Context18commit_transactionEPNS_11TransactionE + 280
    15  QuartzCore                          0x000000010ff6c767 _ZN2CA11Transaction6commitEv + 475
    16  UIKit                               0x0000000111435a97 _UIApplicationFlushRunLoopCATransactionIfTooLate + 206
    17  UIKit                               0x0000000111c456e0 __handleEventQueue + 5672
    18  CoreFoundation                      0x0000000110fbe311 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + 17
    19  CoreFoundation                      0x0000000110fa359c __CFRunLoopDoSources0 + 556
    20  CoreFoundation                      0x0000000110fa2a86 __CFRunLoopRun + 918
    21  CoreFoundation                      0x0000000110fa2494 CFRunLoopRunSpecific + 420
    22  GraphicsServices                    0x00000001163a0a6f GSEventRunModal + 161
    23  UIKit                               0x000000011143c964 UIApplicationMain + 159
    24  FH Harvey                           0x000000010fe221bf main + 111
    25  libdyld.dylib                       0x000000011491368d start + 1
)
libc++abi.dylib: terminating with uncaught exception of type NSException
(lldb) 

Upvotes: 1

Views: 1670

Answers (4)

Sanjukta
Sanjukta

Reputation: 1055

Please write :

for (int i = 0; i < [_daysOfWeek count]; i++)

It will help you.

Upvotes: 0

KrishnaCA
KrishnaCA

Reputation: 5695

Just changing you for loop logic from i <= [_daysOfWeek count] to i < [_daysOfWeek count] should resolve your problem. However, to avoid mistakes like this in future, I suggest you to use enumerateObjectsUsingBlock method of NSArray. It can be done in the following way:

NSArray *daysOfWeek = [NSArray arrayWithObjects:@"Monday",@"Tuesday",@"Wednesday",@"Thursday",@"Friday",@"Saturday",@"Sunday", nil];
[daysOfWeek enumerateObjectsUsingBlock:^(NSString*  _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {

}];

Upvotes: 0

SKD
SKD

Reputation: 1497

DEEPAK kumar just verify your logic. Your array having 7 values and you are iterating it 8 times. Just change the logic

for (int i = 0; i < [_daysOfWeek count]; i++)

or

use for each loop as Nirav D describes (most optimized way).

Happy coding..

Upvotes: 0

Nirav D
Nirav D

Reputation: 72410

The problem is with your for loop. Array index start with 0 so change your for loop to:

for (int i = 0; i < [_daysOfWeek count]; i++) {

You are using i<=[_daysOfWeek count] that is the reason you are getting index 7 beyond bounds [0 .. 6] crash.

Instead of using for loop you can use for each loop and it easy to implement and it will never cause you index out of bound crash.

 for (NSString* str in _daysOfWeek) {
     NSLog(@"%@",str);
 }

Upvotes: 2

Related Questions