gpt4 book ai didi

c++ - 将 variant、vector 和 vector> 转换为我选择的等效类型

转载 作者:塔克拉玛干 更新时间:2023-11-03 01:34:37 27 4
gpt4 key购买 nike

我的问题涉及 boost::variant 转换与 C++ 中的 std::vector 的混合。在我的项目中,我使用变体作为 SQL 的输出。我将始终只使用一种类型的变体。我想要做的是从变量、变量 vector 或变量的 2xvector 到我选择的等效类型的简单转换。天真地,我需要一些类似的东西:

std::vector < int > my_variable = convert(some_variant_vector)

首先这是我的设置:

#include "boost\variant.hpp"
#include "boost\date_time\gregorian\gregorian.hpp"
typedef boost::variant< int, std::string, boost::gregorian::date> _var;
typedef std::vector<_var> _vec_var;
typedef std::vector<_vec_var> _vec2_var;

我想有一种简单的方法将 _var(或 _vec_var_vec2_var)转换为 int/string/date,具体取决于根据我的需要。来自以下post我知道我的答案应该是这样的:

template<typename T>
struct converter_visitor : public boost::static_visitor<T>
{
const _var &converter;
converter_visitor(const _var &r) : converter(r) {}
T operator()(const _var &) const{
return boost::get<_var>(converter);
}

const _vec_var &v_converter; // case of vector<>
converter_visitor(const _vec_var &r) : v_converter(r) {}
T operator()(const _vec_var &) const{
T ans;
ans.reserve(_cont.size());
for (int i = 0; i < _cont.size(); ++i)
ans.push_back(boost::get<T>(v_converter[i]));
return ans;
}

const _vec2_var & v2_converter; // case of vector<vector>
converter_visitor(const _vec2_var &r) : v2_converter(r) {}
T operator()(const _vec2_var &) const {
T ans;
ans.reserve(v2_converter.size(), v2_converter[0].size());
for (int i = 0; i < _cont.size(); ++i)
{
for (size_t j = 0; j < v2_converter[0].size(); j++)
{
ans.push_back(boost::get<T>(v2_converter[i][j]));
}
}
return ans;
}
};

int main()
{
_var variable = 1;
int integer_conversion;
boost::apply_visitor(converter_visitor(test), integer_conversion);
return 0;
}

不幸的是,我已经被困了一段时间,因为它没有按预期工作,甚至没有编译。

最佳答案

我会建议以下内容以获得您想要的类型:

template<typename T>
class converter_visitor : public boost::static_visitor<>
{
public:
std::vector<T>& vec;

converter_visitor(std::vector<T>& r) : vec(r) {}

// only push back values of specific types...
void operator()(const T& u) const {
vec.push_back(u);
}

// ignore other types...
void operator()(...) const {}
};

template<typename T>
converter_visitor<T> make_visitor(std::vector<T>& r) { return converter_visitor<T>(r); }

然后将其汇集到可以处理嵌套 vector 的递归过滤器函数:

template<typename T,typename U>
void filter(std::vector<T>& result,const U& var) {
boost::apply_visitor( make_visitor(result), var );
}

template<typename T,typename U>
void filter(std::vector<T>& result,const std::vector<U>& cont) {
std::for_each(cont.begin(),cont.end(),[&](const U& c) {
filter(result,c);
});
}

然后你可以这样做:

_var v = 314;
std::vector<int> result;
filter(result,v);
print(result);

result: 314

_vec_var v;
v.push_back(2);
v.push_back(3);
v.push_back("hello");
v.push_back(5);
v.push_back(7);
v.push_back("world");

std::vector<int> result;
filter(result,v);
print(result);

std::vector<std::string> result2;
filter(result2,v);
print(result2);

result1: 2 3 5 7
result2: hello world

_vec_var v1;
v1.push_back(11);
v1.push_back(13);
v1.push_back("see ya");

_vec_var v2;
v2.push_back(17);
v2.push_back(19);
v2.push_back("later");

_vec2_var vv;
vv.push_back(v1);
vv.push_back(v2);

std::vector<int> result;
filter(result,vv);
print(result);

std::vector<std::string> result2;
filter(result2,vv);
print(result2);

result1: 11 13 17 19
result2: see ya later

see live demo here

关于c++ - 将 variant、vector<variant> 和 vector<vector<variant>> 转换为我选择的等效类型,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41825977/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com