在下面的代码中,我丢失了字符串中的最后一个字符。
NSString *testString = @"— choose a category —";
NSData *testData = [NSData dataWithBytes:[testString UTF8String] length:[testString length]];
NSString *newString = [[[NSString alloc] initWithData:testData encoding:NSUTF8StringEncoding] autorelease];
调试器显示如下:
(lldb) po testString
(NSString *) $7 = 0x002ec7f0 — choose a category —
(lldb) po testData
(NSData *) $8 = 0x1003d1c0 <e2809420 63686f6f 73652061 20636174 65676f72 79>
(lldb) po newString
(NSString *) $9 = 0x09109f50 — choose a category
(lldb)
字节对应的字符如下:
e2 80 94 | 20 | 63 | 68 | 6f | 6f | 73 | 65 | 20 | 61 | 20 | 63 | 61 | 74 | 65 | 67 | 6f | 72 | 79 |
EM DASH | sp | c | h | o | o | s | e | sp | a | sp | c | a | t | e | g | o | r | y | sp | EM DASH
我在上传到服务器的较长字符串中看到了同样的问题,而且似乎总是使用多字节 UTF8 字符。
当我从服务器下载记录的数据时,unicode 字符(尚未被截断)正确显示。但是我的服务器上记录的字符串被截断了,表明截断存在于 NSData 对象中。
我在这里做错了什么?