如何以优雅/快速的方式将STL字符串向量转换为char*

How to convert STL string vector into char* in an elegant/quick way?

本文关键字:字符串 STL 向量 转换 char 方式      更新时间:2023-10-16

这分为更小的阶段:

  1. 如何计算向量中所有字符串的总长度?
  2. 分配char* mem空间
  3. 将向量字符串复制到该空格

是否有一种快速而优雅的方法来做到这一点?

我能想到的最优雅但可能不是最快的方法是:

std::string s = std::accumulate(v.begin(), v.end(), std::string());
char * c = new char[s.size() + 1];
std::strcpy(c,s.c_str());

虽然我自己不是裸动态分配的粉丝,而且我个人永远不会使用它,但我将把这个问题留给你来解决。

如果需要在元素之间添加空格分隔符,则会变得有点复杂,我可能会使用不同的解决方案,如:

std::ostringstream oss;
std::copy(v.begin(), v.end(), std::ostream_iterator<std::string>(oss," "));
size_t sz = oss.str().size();
if(sz) --sz; // truncate trailing space if there is one
char * c = new char[sz+1];
std::copy_n(oss.str().c_str(), sz, c);
c[sz] = 0;

下面是c++ 0x的实现:

#include <cstddef>
#include <algorithm>
#include <numeric>
#include <string>
#include <vector>
std::vector<char> concat_strings(std::vector<std::string> const& vecs)
{
    std::size_t const cumulative_length = std::accumulate(
        vecs.begin(),
        vecs.end(),
        static_cast<std::size_t>(0),
        [](std::size_t const acc, std::string const& str)
        {
            return acc + str.size();
        }
    );
    std::vector<char> ret;
    ret.reserve(cumulative_length);
    std::for_each(
        vecs.begin(),
        vecs.end(),
        [&ret](std::string const& str)
        {
            ret.insert(ret.end(), str.begin(), str.end());
        }
    );
    return ret;
}

得到的std::vector<char>就是有效的char*

对于c++ 03,它将大致相同,但您需要适当的函函数来代替lambda(或使用c++ 03 lambda库,例如Boost.Phoenix)。

这不是一个优雅的要求,所以我想不出什么优雅的解决方案。

未测试的代码

vector<string> vec = ...;
size_t total_size = 0;
for (size_t i = 0; i < vec.size(); ++i)
  total_size += vec[i].size();
char* mem = new char[total_size];
char* p = mem;
for (size_t i = 0; i < vec.size(); ++i)
{
  memcpy(p, vec[i].data(), vec[i].size());
  p += vec[i].size();
}

这是STL的方式:

#include <algorithm>  // std::copy
#include <iostream>   // std::cout
#include <iterator>   // std::ostream_iterator
#include <sstream>    // std::ostring_stream
#include <string>     // std::string
#include <vector>     // std::Vector
using namespace std;
typedef std::vector<std::string> string_vector;
int main( int argc, char ** argv )
{
  string_vector v;
  v.push_back("string 1, ");
  v.push_back("string 2, ");
  v.push_back("string 3");
  std::ostringstream os;
  std::copy( v.begin(), v.end(), std::ostream_iterator<std::string>( os, "" ) );
  std::string result = os.str();
  std::cout << "result: " << result << std::endl;
  return 0;
}
输出:

result: string 1, string 2, string 3