4

我读了这篇文章:http ://weakreference.wordpress.com/2011/06/22/overriding-nslog-on-ios/ 。

文章的思路是把这两个东西加到你app的prefix.pch文件中,这样你就可以覆盖NSLog的行为了。

我要添加的两件事是:

#define NSLog(...) customLogger(__VA_ARGS__);

void customLogger(NSString *format, ...) {
    va_list argumentList;
    va_start(argumentList, format);
    NSMutableString * message = [[NSMutableString alloc] initWithFormat:format
        arguments:argumentList];

    [message appendString:@"Our Logger!"]; // Our custom Message!
    NSLogv(message, argumentList); // Originally NSLog is a wrapper around NSLogv.
    va_end(argumentList);
    [message release];
}

xCode 抛出一个错误 match-o 错误,它找到了 customLogger 的重复项。

有没有人成功覆盖 NSLog?

谢谢!

编辑以回应 Rob:

好,太棒了。我们正在取得进展!我按照你的要求移动了东西。这是我们现在所拥有的:

我的自定义记录器:

void customLogger(NSString *format, ...) {

    va_list args;
    va_start(args, format);
    va_end(args);
    [newLogger log:format withArgs:args];
}

//This is a newLogger Method
+ (void) log:(NSString *)format withArgs:(va_list) args{

    NSArray *occ = [format componentsSeparatedByString:@"%@"];

    NSInteger characterCount = [occ count]; 

    NSArray *stringItems = [format componentsSeparatedByString:@"%@"];

    NSMutableString *tmp = [[NSMutableString alloc] initWithFormat: @"%@",[stringItems objectAtIndex:0]];

    for( int i = 1; i < characterCount; i++ ) {
        NSString *value = va_arg(args, NSString *);
        [tmp appendString:value];
        [tmp appendString:[stringItems objectAtIndex:i]];
    }

    // Need to alter the above and actually do something with the args! 
    [tmp appendString:@"\n"];
    [[newLogger sharedInstance].logBuffer appendString:tmp];

    if ([newLogger sharedInstance].textTarget){
        [[newLogger sharedInstance].textTarget setText:sharedInstance.logBuffer];
    }
}

当我调用 +log 时,线程 1 上出现 SIBABRT 错误。

4

2 回答 2

5

听起来您在文件中定义customLogger.pch。这意味着每个.m文件都包含它,因此.o您的项目创建的每个文件都包含自己的customLogger. 这就是为什么您会从链接器中得到重复的符号定义错误。

您只需在customLogger中声明.pch,如下所示:

void customLogger(NSString *format, ...);

并创建一个customLogger.m包含定义的文件。

于 2012-07-11T21:50:53.120 回答
-1

试试这个代码。它覆盖了 NSLog。在最后的 ClassName-Prefix.pch 文件中编写以下代码

#ifdef DEBUG
#    define DLog(...) NSLog(__VA_ARGS__)
#else
#   define DLog(...) /* */
#endif

在 ViewController.m 文件中,

- (void)viewDidLoad
{
    [super viewDidLoad];
    DLog(@"printing from DLog");

    DLog(@"printing again from DLog");

// Do any additional setup after loading the view, typically from a nib.
}

这将在控制台中打印句子。如果您发现困难,请告诉我。

于 2014-01-24T13:46:34.067 回答