Segfault from NSLog?
问题描述:
我看到使用NSLog的段错误,具体来说,它在64位设备上,具有SEGV_ACCERR
。我是iOS新手,所以我有点困惑。Segfault from NSLog?
这里的堆栈跟踪:
Exception Type: SIGSEGV
Exception Codes: SEGV_ACCERR at 0x108074000
Crashed Thread: 0
Thread 0 Crashed:
0 libsystem_platform.dylib 0x00000001826ea31c _platform_memmove + 300
1 libsystem_asl.dylib 0x00000001825289a4 asl_string_append_no_encoding_len + 92
2 libsystem_asl.dylib 0x0000000182522fc8 asl_string_new + 108
3 libsystem_asl.dylib 0x0000000182522df4 asl_msg_to_string_raw + 68
4 libsystem_asl.dylib 0x00000001825228dc _asl_send_message + 828
5 libsystem_asl.dylib 0x00000001825224fc asl_send + 8
6 CoreFoundation 0x0000000182a6fa1c __CFLogCString + 568
7 CoreFoundation 0x0000000182a6f7ac _CFLogvEx2 + 300
8 CoreFoundation 0x0000000182a6fc14 _CFLogvEx3 + 152
9 Foundation 0x0000000183435dd8 _NSLogv + 128
10 Foundation 0x000000018336ae04 NSLog + 28
下面是调用此代码:
NSString *truncated = [NSString stringWithUTF8String:buffer];
// Using original NSLog to print.
#undef NSLog
NSLog(@"%@", truncated);
,它从我的NSLog
通话崩溃。
其中buffer
只是一个字符缓冲区。
我的问题具体是:
- 它甚至有可能从使用苹果提供的
NSLog
崩溃?或者我的堆栈跟踪错误? -
SEG_ACCERR
在这种情况下意味着什么? - 我怎么能找到这是否是由不良内存问题引起的?
- 是什么东西在多线程下的asl文件?
- 我应该如何调试这个?
任何帮助将不胜感激!谢谢!
答
你说缓冲区是一个字符缓冲区。如果是这样的情况下,你应该初始化这样
的NSString *截断=字符串[[NSString的页头] initWithBytes:缓冲器 长度:LEN NSUTF8StringEncoding];
其中len是缓冲区中字符的长度。
也许缓冲区无效,例如,不是UTF8。 – Justlike