C++2017 参考 std::vector<std::variant>
C++2017 Reference to std::vector<std::variant>
我尝试存储对由std::variant
组成的std::vector
的引用。我可以创建一个const std::variant<T>&
到一个vector
的元素,但我很难存储对整个向量的引用。我想答案与通过引用存储的这个 postc++ 变体类成员有关,但我无法将其应用于我的情况。
#include <vector>
#include <variant>
using MType = std::variant<int, double>;
int main()
{
std::vector<int> intVec{ 1,2,3,4 };
std::vector<double> dlVec{ 1.1,2.2,3.3,4.4 };
const MType& refVar = intVec[0];
// const std::vector<MType>& refVec = intVec; // compiler error: not suitable construction
}
你可以
将int
分配给variant<int, double>
,也可以为variant<int, double>
分配double
,但两者都不是variant<int, double>
,vector<variant<int, double>>
也不是vector<int>
或vector<double>
。
你根本做不到。
你有没有可能variant<vector<int>, vector<double>>
?
我可以创建对向量元素的
const std::variant&
,
跟
const MType& refVar = intVec[0];
您不会创建对 intVec
元素的引用,而是创建一个临时的(具有生存期扩展)。
所以它基本上是:
const std::variant<int, double> var = intVec[0];
但我很难存储对整个向量的引用
与 std::vector
相同,您可以创建一个std::vector<std::variant<int, double>>
:
std::vector<std::variant<int, double>> varVec(intVec.begin(), intVec.end());
相关文章:
- 使用std::multimap迭代器创建std::list
- C++中std::resize(n)和std::shrink_to_fit之间的区别
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 如何导出包含具有"std::unique_ptr"值的"std::map"属性的
- 从持续时间构造std::chrono::system_clock::time_point
- std::具有相同基类的类的变体
- std::向量与传递值的动态数组
- 使用std::vector的OpenCL矩阵乘法
- std::map<struct,struct>::find 找不到匹配项,但是如果我循环通过 begin() 到 end(),我在那里看到匹配项
- std::condition_variable::wait()如何评估给定的谓词
- 如何获取std::result_of函数的返回类型
- std::原子加载和存储都需要吗
- 将对象移动到std::shared_ptr
- std::vector<;uint8_t>;当C++11/14启用时,手动复制而不是调用memcpy
- 是std :: set&lt; std :: future&gt;不可能存在
- 在修改列表后,std :: list&lt; t&gt; :: end()的值是否会更改
- 使用 std::vector<boost::shared_ptr<Base_Class>> 或 boost::p tr_vector 的性能注意事项是什么<Base>
- std::map<std::set, double> AND std:<long>map< std::p air<long, long>, double>
- 如何获取std::vector<DMatch>