c – std ::在std :: string和std :: vector之间移动

c – std ::在std :: string和std :: vector之间移动,第1张

概述我正在和2个图书馆合作.一个接收并返回std :: strings,而另一个使用std :: vector< unsigned char> s. 如果我可以从std :: string和std :: vector< unsigned char>中窃取底层数组,那将是很好的并且能够将它们彼此移动而不会过度复制. ATM我使用的东西: const unsigned char* raw_memory = 我正在和2个图书馆合作.一个接收并返回std :: strings,而另一个使用std :: vector< unsigned char> s.

如果我可以从std :: string和std :: vector< unsigned char>中窃取底层数组,那将是很好的并且能够将它们彼此移动而不会过度复制.

ATM我使用的东西:

const unsigned char* raw_memory =    reinterpret_cast<const unsigned char*>(string_value.c_str()),std::vector<unsigned char>(raw_memory,raw_memory + string_value.size();

另一方面:

std::string(    reinterpret_cast<const char*>(&vector_value[0]),vector_value.size());

能够定义一个:

std::string move_into(std::vector<unsigned char>&&);std::vector<unsigned char> move_into(std::string&&);
解决方法 这不可能.

矢量和字符串类别不提供方式来分别从矢量或字符串中除外.他们不是要交换内容.

问题的问题是矢量和字符串可能有广泛不同的底层表示.通常在gcc中,字符串使用旧的COW(复制写入)“优化”,这与典型的向量表示(通常只是三分之一的指针/ size_t属性)有很大不同.

如果您正在处理原始字节,则将库决定将其放入字符串,并重新构建它,如果可以的话.

否则:复制. reinterpret_cast不应该是必需的,因为char和unsigned char在它们之间有隐式转换(现在,char通常默认为unsigned).

总结

以上是内存溢出为你收集整理的c – std ::在std :: string和std :: vector之间移动全部内容,希望文章能够帮你解决c – std ::在std :: string和std :: vector之间移动所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1247690.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-07
下一篇 2022-06-07

发表评论

登录后才能评论

评论列表(0条)

保存