如何在 c++ 中将向量转换为<string>常量字符* const*?

How do I convert a vector<string> to a const char* const* in c++?

本文关键字:常量 gt string 字符 const lt 向量 转换 c++      更新时间:2023-10-16

我正在尝试将数据转换为特定单元测试的正确格式。 任务是挖掘一组单词,单元测试将确保结果正确。我无法访问单元测试,只能访问采用常量字符* const* 结果的声明。

所以我需要得到我的

std::vector<string> Words; 

const char* const* Result;

除以非字母字符(例如空格(。

我知道这是一个指向常量字符的常量指针,所以我不确定在这里做什么,因为它们都是常量?

任何指针(单词双关语不是真的打算(都值得赞赏!

您无法有意义地将一个转换为另一个。但是,您可以将std::string数组转换为指向 char 的指针数组,并且指向此类数组的第一个元素的指针将与您想要的结果兼容:

std::vector<const char*> Ptrs;
std::transform(
std::cbegin(Words), std::cend(Words),
std::back_inserter(Ptrs),
[](auto& str)  { return str.c_str(); }
);
const char* const* Result = Ptrs.data();

请记住,字符串本身仍存储在std::string对象中,并且新矢量中的这些指针仅在原始矢量中的字符串存在、未调整大小且原始矢量本身未调整大小时才有效。

并且,指向新矢量的第一个元素的指针仅在该矢量存在且未调整大小时才有效。

似乎很容易

#include <algorithm>
#include <functional>
// ...
std::vector<char const*> result_owner(Words.size());
std::transform(begin(Words), end(Words), begin(result_owner), 
std::mem_fn(&std::string::c_str));
const char* const* Result = result_owner.data();

仅仅因为Result必须提供缓冲区的常量视图,并不意味着缓冲区本身必须真正是常量视图。所以这只是我们通过在std::string::c_str成员上投影Words而获得的另一个向量。

在那之后,Result可以简单地成为result_owner.data();的另一个参考。

当然,这假设Result不必拥有它指向的缓冲区。最好避免拥有原始指针。

穴居人的方法:)

#include <iostream>
#include <vector>
#include <string>
#include <string.h>
using namespace std;
char **foo(const vector<string> &vec_of_strings)
{
int num_strings = vec_of_strings.size();
int max_str_len = 0;
for (int i=0;i<num_strings;i++)
{
if (max_str_len < vec_of_strings[i].length()) {
max_str_len = vec_of_strings[i].length();
}
}
// for null termination ...
max_str_len++;
char **result = (char **) malloc(num_strings);
for (int i=0;i<num_strings;i++)
{
result[i] = (char *) malloc(max_str_len);
strcpy(result[i],vec_of_strings[i].c_str());
}
return result;
}
int main(int argc, char **argv)
{
vector<string> vec_of_strings;
vec_of_strings.push_back("Long");
vec_of_strings.push_back("Livvvvvvvve");
vec_of_strings.push_back("The");
vec_of_strings.push_back("King");
const char * const * Result = foo(vec_of_strings);
for (int i=0;i<4;i++)
{
printf("%sn",Result[i]);
}
}