我正在尝试将数据转换为适合特定单元测试的格式。任务是挖掘一组单词,单元测试将确保结果是正确的。我无法访问单元测试,只需要获取const char * const * Result的声明。
所以我需要得到我的
std::vector<string> Words;
至
const char* const* Result;
除以非alpha字符(例如空格)。
我知道这是一个常量字符的常量指针,所以我不知道该怎么做,因为它们都是常数?
任何指针(单词双关语并非真正意图)表示赞赏!
你不能有意义地将一个转换为另一个。但是,您可以将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
必须提供缓冲区的const视图,并不意味着缓冲区必须真正是const本身。所以它只是我们通过在Words
成员上投射std::string::c_str
获得的另一个向量。
之后,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("%s\n",Result[i]);
}
}