尝试在实例方法中NSLog NSNumber ivar

时间:2010-01-11 23:24:59

标签: objective-c nsnumber nslog

我正在研究跟踪不同歌曲的控制台应用。我正在努力让歌曲课程首先开始,并试图将已经为歌曲持续时间分配的nsnumber记录到nslog语句中:

//
//  Song.h
//  MusicCollection.15.9   
//
//  Created by Nicholas Iannone on 1/11/10.
   //  Copyright 2010 __MyCompanyName__. All rights reserved.
   //

   #import <Foundation/Foundation.h>


@interface Song : NSObject {

NSString *songTitle;
NSString *songArtist;
NSString *songAlbum;
NSNumber *SongDuration; 
}
@property (nonatomic, retain) NSString *songTitle, *songArtist, *songAlbum;
@property (nonatomic, retain) NSNumber *SongDuration;

-(id) init;


-(void) printSong;



@end


//
//  Song.m
//  MusicCollection.15.9    
//
//  Created by Nicholas Iannone on 1/11/10.
//  Copyright 2010 __MyCompanyName__. All rights reserved.
//

#import "Song.h"


@implementation Song

@synthesize  songTitle, songArtist, songAlbum;
@synthesize SongDuration;

-(id) init
{

if (self = [super init]) {

    [SongDuration numberWithInteger];
}

-(void) printSong
{



NSLog(@"===============Song Info==================");
NSLog (@"|                                       |");
NSLog (@"| %-31s |", [songTitle UTF8String]);
NSLog (@"| %-31s |", [songArtist UTF8String]);
NSLog (@"| %-31s |", [songAlbum UTF8String]);                                       
NSLog (@"| %31@   |"  [self songDuration]);
NSLog (@"|                                       |");
NSLog (@"|                                       |");
NSLog (@"=========================================");

}
@end

基本上我不确定如何在调用print方法时将nsnumber合并到nslog语句中,而且我不确定如何处理这些nsobjects ingeneral它们似乎介于我要创建的对象之间交流型。任何有关如何处理这些问题的说明都将受到赞赏。

谢谢,

尼克

1 个答案:

答案 0 :(得分:34)

要在格式字符串中插入对象的描述,请使用%@

您也可以使用标题/艺术家/专辑NSStrings进行此操作,因此您无需首先致电-UTF8String

对于您的歌曲持续时间,您可以直接记录NSNumber,也可以通过调用-floatValue-integerValue并使用%f%d记录来记录浮点数或整数表示形式

示例:

NSLog(@"%@", songTitle);
NSLog(@"%@", songDuration);
NSLog(@"%f", [songDuration floatValue]);
NSLog(@"%d", [songDuration integerValue]);