将NSString字符串转换为char *时,并没有一个直接可以使用的API,但是却可以调用[NSString UTF8String]的方法将NSString转换成const char *,然后可以通过内存拷贝的方法将一个const char *转换成char *。
在为一个cha *分配内存之前需要知道被拷贝的字符串在内存中所占的字节数,所以我就使用了下面的方法:
NSString *srcString = @"测试abc.";
int length1 = [srcString length];
char *dstString = (char*)malloc(sizeof(char)*(length + 1));
memset(dstString, 0, (length + 1));
memcpy(dstString, [filePath UTF8String], length);
经过调试发现如果srcString中不存在中文的话,这种方法是正确的,只要有中文转换后就会出现乱码。最终发现length这个值并不是字符串实际在内存中占有的字节数,查阅帮助文档:
length
Returns the number of Unicode characters in the receiver.
- (NSUInteger)length
Return Value
The number of Unicode characters in the receiver.
关键就是在Unicode characters上,苹果会认为一个中文字符在内存中占用了一个字节,所以改用了以下方法:
NSString *srcString = @"测试abc.";
int length2 = strlen([srcString UTF8String]);
char *dstString = (char*)malloc(sizeof(char)*(length + 1));
memset(dstString, 0, (length + 1));
memcpy(dstString, [filePath UTF8String], length);
在调试时发现length1 = 6,length2 = 10,查看内存发现苹果下一个中文字符占有3个字节,而不是我们通常认为的2个字节。
仅以此提醒自己多看帮助文档。