在使用 Objective-C++ 时,我经常发现自己使用 initWithCString 将 std::string 转换为 NSString。为了简化流程,我在 NSString 上创建了一个类别,如下所示:
@implementation NSString (NSStringFromCPP)
+(NSString*)stringFromCppStringstd::string)cppString
{
return [[NSString alloc] initWithCString:cppString.c_str() encoding:NSStringEncodingConversionAllowLossy];
}
-(std::string)cppString
{
return std::string([self cStringUsingEncoding:NSStringEncodingConversionAllowLossy]);
}
@end
这使得 NSString 和 std::string 之间的双向转换相当容易。似乎必须有一种方法可以从 std::string 隐式转换为 NSString。我知道在 Objective-C 中没有构造函数这样的东西,那么如何在不必使用 stringFromCppString 的情况下完成以下操作
-(void)somethingNSString*)someString
{
NSLog(@"%@", someString);
}
-(void)activity
{
std::string activityName = "Calculator";
[self something:[NSString stringFromCppString:activityName]];
}
在大多数情况下,使用 std::string 的代码可以与使用 NSString 的代码分开。但是,会发生相当多的桥接,并且到处都是 stringFromCppString 代码会让人分心。
Best Answer-推荐答案 strong>
您应该将 std::string const & 作为 Obj-C 方法中的参数类型传递。
+(NSString*)stringFromCppStringstd::string const &)cppString;
此外,不要忘记当编译为 .mm 时,您可以使用普通的 C++,因此您可能需要考虑像重载这样简单的事情...
std::string
cppString(char const *s)
{
return s;
}
std::string const &
cppString(std::string const &s)
{
return s;
}
std::string
cppString(NSString *s)
{
return [self cStringUsingEncodingESIRED_ENCODING];
}
反之...
NSString *
objcString(char const *s)
{
return [NSString stringWithCString:s encodingESIRED_ENCODING];
}
NSString *
objcString(std::string const &s)
{
return objcString(s.c_str());
}
NSString *
objcString(NSString *s)
{
return s;
}
现在,无论何时你想要一个 C++ std::string,只需调用 cppString ,无论何时你想要一个 Obj-C NSString,只需调用 objcString ,而你不需要真的不必关心“真正的”字符串是什么......
或者,您可以制作自己的字符串包装器,使用您使用的转换运算符...这也非常简单。
但是,一般来说,您可能希望您的 C++ 是 C++,您的 ObjC 是 ObjC,并使用 .mm 作为轻量级粘合剂。
关于c++ - 使用 std::string 隐式构造 NSString,我们在Stack Overflow上找到一个类似的问题:
https://stackoverflow.com/questions/23227696/
|