0

我正在尝试使用快速枚举来打印播放列表中的所有歌曲,但似乎我做错了。有人可以帮我吗?我已经定义了一个这样的 Song 类:

@interface Song : NSObject
@property (nonatomic,strong) NSString *title;
@property (nonatomic,strong) NSString *artist;
@property (nonatomic,strong) NSString *album;
@property (nonatomic,strong) NSString *playtime;
-(void) displaySong;
@end

displaySong 函数如下所示:

-(void) displaySong {
NSLog(@"%@ - %@ [%@] - %@\n", artist, title, album, playtime);
}

现在,到 PlayList 类:

@interface PlayList : NSObject{
NSString *name;
NSMutableArray *playlist;
}
-(void) addSongToPlaylist: (Song *) song;
-(void) displayPlaylist;
@end

@implementation PlayList
-(void) addSongToPlaylist: (Song *) nameOfSong{
    [playlist addObject:nameOfSong];
}

-(void) displayPlaylist{
NSLog(@"Playlist called %@:\n", name);
for(id obj in playlist)
{
    if([obj isKindOfClass:[Song class]])
    [obj displaySong];
}
}

// I also tried the displayPlaylist method this way, but it wasn't working either
-(void) displayPlaylist{
NSLog(@"Playlist called %@:\n", name);
for(Song *song in playlist)
{
    [song displaySong];
}

@end

有人可以向我解释为什么我的代码不起作用吗?
什么 displayPlaylist 方法更好?

4

2 回答 2

3

您永远不会创建播放列表

在 Playlist 类的 init 中添加一个playlist = [[NSMutableArray alloc] init] ;

并考虑为播放列表使用属性(伙计——相似的名字很烦人!)

如果你不想有一个初始化,你也可以这样做:

-(void) addSongToPlaylist: (Song *) nameOfSong{
    if(!playlist)
        playlist= [[NSMutableArray alloc] init];
    [playlist addObject:nameOfSong];
}

回答第二个问题:这取决于

  • 如果你知道,数组中只有 Song 的实例,第二个版本更好,因为更快一点

  • 如果你不知道,它是第一个,否则一个对象会收到一条消息,它无法处理 -> 崩溃

  • 或者你可以做

    for(id obj in playlist)
    {
        if([obj respondsToSelector:@selector(displaySong)])
        [obj displaySong];
    }
    

    如果您想确定,无论它是什么对象,都可以理解该消息。

于 2012-03-04T22:19:18.037 回答
1

您似乎没有初始化播放列表数组。您可以通过检查 nil 或覆盖 PlayList 类的 init 方法来懒惰地在您的方法中执行此操作。

于 2012-03-04T22:21:41.420 回答