我发现自己经常围绕C风格的API编写c ++包装器,我写的一些常见的浪费代码如下:
//getSomeString() wraps C api that gets some C string from somewhere
std::string MyClass::getSomeString()
{
char buffer[BUFFER_MAX];
memset(buffer, '\0', BUFFER_MAX);
auto result = GetCApiString(buffer, BUFFER_MAX); //C style string getter
return (result == NO_ERROR) ? std::string{buffer} : ""; //Copy here
}
但我真的很想做这样的事情:
//getSomeString(): as before
std::string MyClass::getSomeString()
{
DirectStringFillIterator<char> returnString; // <--HERE. Is something like this possible?
auto result = GetCApiString(returnString, BUFFER_MAX);
return (result == NO_ERROR) ? returnString.str() : "";
}
这样的事情可能吗?
答案 0 :(得分:8)
std::string
保证是连续的(但在我曾经遇到过的每一个实现中,它甚至在C ++ 03中也是如此)。所以,通常你可以做到
std::string MyClass::getSomeString() {
std::string ret(BUFFER_MAX, '\0');
if(GetCApiString(&ret[0], ret.size()) != NO_ERROR) return "";
ret.resize(ret.find_first_of(0));
return ret;
}
这避免了第一个方法的一个副本(从本地缓冲区到返回的字符串),但强制返回的字符串总是分配BUFFER_MAX
个字节,这可能是你的情况下的缺点,也可能不是。 p>