2016-01-21 167 views
2

我看到使用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只是一个字符缓冲区。

我的问题具体是:

  1. 它甚至有可能从使用苹果提供的NSLog崩溃?或者我的堆栈跟踪错误?
  2. SEG_ACCERR在这种情况下意味着什么?
  3. 我怎么能找到这是否是由不良内存问题引起的?
  4. 是什么东西在多线程下的asl文件?
  5. 我应该如何调试这个?

任何帮助将不胜感激!谢谢!

+0

也许缓冲区无效,例如,不是UTF8。 – Justlike

回答

0

你说缓冲区是一个字符缓冲区。如果是这样的情况下,你应该初始化这样

的NSString *截断=字符串[[NSString的页头] initWithBytes:缓冲器 长度:LEN NSUTF8StringEncoding];

其中len是缓冲区中字符的长度。