1

これが私のコードです:

test.h

@interface testAppDelegate : NSObject <NSApplicationDelegate> {
    NSWindow *window;
    IBOutlet NSTableView *test;
    NSMutableArray *internalArray;
}

@property (assign) IBOutlet NSWindow *window;
@property (nonatomic, retain) NSTableView *test;
-(id) initWithArray: (NSArray*) objects;
-(int)numberOfRowsInTableView:(NSTableView *)aTableView;
-(id)tableView:(NSTableView *)aTableView objectValueForTableColumn:(NSTableColumn     *)aTableColumn row:(int)rowIndex;
-(void)tableView:(NSTableView *)aTableView setObjectValue:(id)anObject forTableColumn:(NSTableColumn *)aTableColumn row:(int)rowIndex;

test.m (簡単にするために上の部分は省略しています)

@synthesize window;
@synthesize test;

- (void)applicationDidFinishLaunching:(NSNotification *)aNotification {
    PSClient *client = [PSClient applicationClient];
    NSURL *url = [NSURL URLWithString:@"http://www.apple.com/main/rss/hotnews/hotnews.rss"];
    PSFeed *feed = [client addFeedWithURL:url];
    internalArray = [NSMutableArray array];

    // Retrieve the entries as an unsorted enumerator
    NSEnumerator *entries = [feed entryEnumeratorSortedBy: nil];
    PSEntry *entry;
    // Go through each entry and print out the title, authors, and content
    while (entry = [entries nextObject]) {
        [internalArray addObject:entry.title];
        //NSLog(@"Entry Title:%@", entry.title);
        //NSLog(@"Entry Authors:%@", entry.authorsForDisplay);
        [test reloadData];
        //NSLog(@"Entry Content:%@", entry.content.plainTextString);
    }
}

-(int)numberOfRowsInTableView:(NSTableView *)aTableView{
    NSLog(@"%@", [internalArray count]);
    return [internalArray count];
}

-(id)tableView:(NSTableView *)aTableView objectValueForTableColumn:(NSTableColumn *)aTableColumn row:(int)rowIndex
{
    NSString *string = [internalArray objectAtIndex:rowIndex];
    NSLog(@"%@", string);
    // when I debug, I get same pointers with invalid data
    // each object has "name" message
    // this following line gives invalid pointer and
    // it crashes
    return string;
}

-(void)tableView:(NSTableView *)aTableView setObjectValue:(id)anObject forTableColumn:(NSTableColumn *)aTableColumn row:(int)rowIndex
{
    NSString *string = [internalArray objectAtIndex:rowIndex];
    NSLog(@"%@", string);
    // when I debug, I get same pointers with invalid data
    // each object has "name" message
    // this following line gives invalid pointer and
    // it crashes
    return string;
}
@end

IB では、テーブルビュー (テスト) をアプリのデリゲート (テスト、データソース、およびデリゲート) に接続しています。

何らかの理由でテーブルにデータが表示されず、[test reloadData]; を呼び出すと、アプリがクラッシュする

4

1 に答える 1

1

弾丸でナンバーワン-あなたがinternalArrayそれを作成した後、あなたは保持しません。次のいずれかを使用します。

internalArray = [[NSMutableArray] alloc] init];
internalArray = [[NSMutableArray array] retain];

あなたが現在持っているものの代わりに:

internalArray = [NSMutableArray array];

%@また、私はあなたがおそらくこの方法のフォーマットを望まないと思います:

-(int)numberOfRowsInTableView:(NSTableView *)aTableView{
    NSLog(@"%@", [internalArray count]);
    return [internalArray count];
}

そのコードは確かに(よく、しばしば)あなたがそうするときにクラッシュを引き起こします[tableView reloadData]

では、にオブジェクトを追加するたびapplicationDidFinishLaunching:にを呼び出す必要はありません。そのループの最後に一度だけ実行してください。reloadDatainternalArray

の実装setObjectValue:forTableColumn:row:も意味がありません。次のようになります。

-(void)tableView:(NSTableView *)aTableView setObjectValue:(id)anObject forTableColumn:(NSTableColumn *)aTableColumn row:(int)rowIndex
{
    NSLog(@"%@", anObject);
    [internalArray replaceObjectAtIndex:rowIndex withObject:anObject];
}

うまくいけば、それらはあなたが始めるためのいくつかのアイデアです。

于 2010-01-30T21:45:38.927 に答える