首先,您必须使用Objective-C ++才能在最短的时间内完成工作;确保将所有*.m
文件重命名为的最简单方法*.mm
到目前为止,将C ++ std::string
放入的最有用(不建议使用)的手动方法NSString
是:
std::string param; // <-- input
NSString* result = [NSString stringWithUTF8String:param.c_str()];
NSString* alternative = [[NSString alloc] initWithUTF8String:param.c_str()];
这在大多数情况下都可以使用-如果您不进行特定的编码检测和转换,那么UTF-8将使非拉丁字符“正常工作”会给您带来很好的效果。
但是,如果您要开发更大的应用程序,或者您不是唯一正在开发该应用程序的人,则可能需要更易于应用的东西。
改编自cocoa-dev邮件列表档案
@interface NSString (cppstring_additions)
+(NSString*) stringWithwstring:(const std::wstring&)string;
+(NSString*) stringWithstring:(const std::string&)string;
-(std::wstring) getwstring;
-(std::string) getstring;
@end
@implementation NSString (cppstring_additions)
#if TARGET_RT_BIG_ENDIAN
const NSStringEncoding kEncoding_wchar_t = CFStringConvertEncodingToNSStringEncoding(kCFStringEncodingUTF32BE);
#else
const NSStringEncoding kEncoding_wchar_t = CFStringConvertEncodingToNSStringEncoding(kCFStringEncodingUTF32LE);
#endif
+(NSString*) stringWithwstring:(const std::wstring&)ws
{
char* data = (char*)ws.data();
unsigned size = ws.size() * sizeof(wchar_t);
NSString* result = [[NSString alloc] initWithBytes:data length:size encoding:kEncoding_wchar_t];
return result;
}
+(NSString*) stringWithstring:(const std::string&)s
{
NSString* result = [[NSString alloc] initWithUTF8String:s.c_str()];
return result;
}
-(std::wstring) getwstring
{
NSData* asData = [self dataUsingEncoding:kEncoding_wchar_t];
return std::wstring((wchar_t*)[asData bytes], [asData length] / sizeof(wchar_t));
}
-(std::string) getstring
{
return [self UTF8String];
}
@end
使用该原位(并适当地#import
编辑),您现在可以:
NSString* result = [NSString stringWithstring:param];
string convertedBack = [result getstring];
和相同std::wstring
,这比方便多了。