我发现自己经常围绕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() : "";
}
这样的事情有可能吗?
发布于 2017-10-22 03:57:25
从C++11开始,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
字节,这在您的情况下可能是也可能不是缺点。
https://stackoverflow.com/questions/46867436
复制相似问题