exe*_*r21 10 iphone cocoa-touch objective-c variadic-functions nsstring
我正在开发一个静态库,将其分发给可能需要调试语句的其他开发人员.所以我有几个级别的日志记录.
为了避免不断出现
if(loggingLevelCurrentlySet >= loggingLevelWantedForThisInstance){
NSLog(@"log this");
}
Run Code Online (Sandbox Code Playgroud)
我创建了一组日志功能包装器.简化版本如下所示:
void myLog(int logLevel, NSString *format, va_list args){
if((loggingLevelCurrentlySet >= logLevel)){
NSLogv(format, args);
}
}
void myLogLevel1(NSString *format, ...){
va_list args;
va_start(args, format);
myLog(1, format, args);
va_end(args);
}
void myLogLevel2(NSString *format, ...){
va_list args;
va_start(args, format);
myLog(2, format, args);
va_end(args);
}
Run Code Online (Sandbox Code Playgroud)
等等
但是现在,我希望从myLog中访问完全格式化的字符串以执行其他操作.
void myLog(int logLevel, NSString *format, va_list args){
NSString *fullString = [NSString stringWithFormat:format, args]; //crashes when args is anything but an empty list
CFStringRef cfsr = CFStringCreateWithFormat(kCFAllocatorDefault, NULL, format, args); //also crashes
//want to use the string here
if((loggingLevelCurrentlySet >= logLevel)){
NSLogv(format, args);
}
}
Run Code Online (Sandbox Code Playgroud)
Joo*_*ost 13
NSString *fullString = [[[NSString alloc] initWithFormat:format arguments:args] autorelease];
Run Code Online (Sandbox Code Playgroud)
有一种方法;)
虽然我建议不要使用函数,但是一些简单的宏定义:
#define myLogLevel1(format, ...) myLog(1, format, __VA_ARGS__)
#define myLogLevel2(format, ...) myLog(2, format, __VA_ARGS__)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3648 次 |
| 最近记录: |