Cela me tourne vraiment la tête ... J'essaie d'accéder à un NSMutableArray dans un IBAction que j'ai défini dans viewDidLoad. Malheureusement, je continue d'obtenir un EXC_BAD_ACCESS. Je suis nouveau à tout cela donc j'apprécierais vraiment un aperçu de ce que je fais mal.SDK iPhone: nombre de NSMutableArray provoque EXC_BAD_ACCESS
Vous trouverez ci-dessous les extraits de code correspondants.
CounterViewController.h:
@interface CounterViewController : UIViewController{
NSMutableArray *countHistoryArray;
}
@property(nonatomic, retain) NSMutableArray *countHistoryArray;
CounterViewController.m:
@implementation CounterViewController
@synthesize countHistoryArray;
- (void)viewDidLoad {
[super viewDidLoad];
//Fill array with some dummy data
self.countHistoryArray = [[NSMutableArray alloc] init];
NSDate *now = [[[NSDate alloc] init] autorelease];
CurrentCount *historicCount = [[[CurrentCount alloc]
initWithCount:[NSNumber numberWithInteger:22]
description:@"Testcount"
dateAndTime:now] autorelease];
[self.countHistoryArray addObject: historicCount];
//Do some logging - everything is working fine here!
NSLog(@"%@", [self.countHistoryArray description]);
}
//Later on we click on a button and want to use the array
- (IBAction)doSomeStuff {
//Let's look at the array again - and now it crashes with EXC_BAD_ACCESS
NSLog(@"%@", [self.countHistoryArray description]);
}
Merci beaucoup!
Manuel
EDIT code supplémentaire comme demandé par @jamapag
CurrentCount.h
#import <Foundation/Foundation.h>
@interface CurrentCount : NSObject {
NSNumber *counterLevel;
NSString *description;
NSDate *dateAndTime;
}
- (id)initWithCount:(NSNumber *)newCounterLevel description:(NSString *)newDescription dateAndTime:(NSDate *)newDateAndTime;
@property(nonatomic, copy) NSNumber *counterLevel;
@property(nonatomic, copy) NSString *description;
@property(nonatomic, copy) NSDate *dateAndTime;
@end
CurrentCount.m
#import "CurrentCount.h"
@implementation CurrentCount
@synthesize counterLevel;
@synthesize description;
@synthesize dateAndTime;
- (id)initWithCount:(NSNumber *)newCounterLevel description:(NSString *)newDescription dateAndTime:(NSDate *)newDateAndTime{
self = [super init];
if(nil != self){
self.counterLevel = newCounterLevel;
self.description = newDescription;
self.dateAndTime = newDateAndTime;
}
return self;
}
-(void) dealloc{
self.counterLevel = nil;
self.description = nil;
self.dateAndTime = nil;
[super dealloc];
}
@end
Je pense que le problème est ailleurs, quelque part entre les deux appels. Cependant, ce code a une fuite à 'self.countHistoryArray = [[NSMutableArray alloc] init]' - vous 'alloc' le tableau, l'accesseur de propriété' retain', mais vous ne libérez pas. Vous devez soit affecter directement à l'ivar, soit ajouter une autorelease. Il vaut probablement la peine de vérifier d'autres utilisations douteuses de 'self.countHistoryArray = ...' qui pourrait causer le problème. – walkytalky
Je fais '- (void) dealloc {[release self.countHistoryArray];}' que je pense faire le travail. Ai-je tort? – sprain
Dans '-dealloc', vous devriez appeler' -release' sur l'ivar lui-même: '[countHistoryArray release]', ou vous devez définir la propriété sur nil, ce qui libèrera tout ce qui était précédemment stocké dans l'ivar, ayant exactement le même effet: 'self.countHistoryArray = nil'. Je préfère la deuxième technique personnellement. –