加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c – 直接从C API填充std :: string

发布时间:2020-12-16 10:08:15 所属栏目:百科 来源:网络整理
导读:我发现自己经常围绕C风格的API编写c包装器,我写的一些常见的浪费代码如下: //getSomeString() wraps C api that gets some C string from somewherestd::string MyClass::getSomeString(){ char buffer[BUFFER_MAX]; memset(buffer,'',BUFFER_MAX); auto
我发现自己经常围绕C风格的API编写c包装器,我写的一些常见的浪费代码如下:

//getSomeString() wraps C api that gets some C string from somewhere
std::string MyClass::getSomeString()
{
    char buffer[BUFFER_MAX];
    memset(buffer,'',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() : ""; 
}

这样的事情可能吗?

解决方法

自从C 11以来,std :: string保证是连续的(但是在我遇到的每个实现中,它甚至在C 03中也是如此).所以,通常你可以做到

std::string MyClass::getSomeString() {
    std::string ret(BUFFER_MAX,'');
    if(GetCApiString(&ret[0],ret.size()) != NO_ERROR) return "";
    ret.resize(ret.find_first_of(0));
    return ret;
}

这避免了第一个方法(从本地缓冲区到返回的字符串)的一个副本,但强制返回的字符串始终分配BUFFER_MAX字节,这可能是也可能不是您的情况下的缺点.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读