我可以将NSLog包装在一个带有可变数量参数的块中吗?

时间:2011-08-31 08:03:51

标签: objective-c logging objective-c-blocks

我正在编写一个Objective-C库,我希望它提供一个简单的可插入日志记录机制,以便库用户可以打开和关闭日志记录。我认为一个有趣的方法是在库类上使用块属性:

typedef void (^Logger)(NSString *fmt, ...);
@property(copy) Logger logger;
logger(@"Foo, %@.", self);

但我不知道如何将变量参数列表传递给NSLog

const Logger SimpleLogger = ^(NSString *fmt, ...) {
    // what goes in here?
};

1 个答案:

答案 0 :(得分:5)

啊,我完全错过了NSLogv

const Logger SimpleLogger = ^(NSString *fmt, ...) {
    va_list arglist;
    va_start(arglist, fmt);
    NSLogv(fmt, arglist);
    va_end(arglist);
};