草庐IT

my_variant_wrapper

全部标签

c++ - 有没有办法从已知的替代方案中重置 std::variant ?

我正在更新一个代码库,该代码库当前正在使用std::variant的自定义等效项到C++17。在代码的某些部分,变体正在从一个已知的替代中重置,因此该类提供了一个方法来断言index()处于当前值,但仍无条件直接调用适当的析构函数。这用于一些紧凑的内部循环,并且具有(测量的)非平凡的性能影响。这是因为它允许编译器在所讨论的替代方案是可简单破坏的类型时消除整个破坏。在我看来,目前的std::variant无法实现这一点。在STL中实现,但我希望我错了。有没有一种我没有看到的方法来完成这个,或者我不走运?编辑:根据要求,这是一个使用示例(使用@T.C的示例作为基础):structS{~S(

c++ - Boost Variant 本质上是 C/C++ 中的 union ?

我想知道c/c++中的BoostVariant和union数据类型之间有什么区别。我知道union数据类型占用相同的内存位置,并且内存区域中最大的数据类型占用使用的内存总量,例如unionspace{charCHAR;floatFLOAT;intINTEGER;}S;应该占用4个字节的内存,因为int和float是最大且相等的大小。BoostVariant和union数据类型在其他方面是否有相同点和不同点?我也知道BoostVariant可以采用任何数据类型,并且它允许数据类型“多态性”(如果我误用了OOP主题词,请纠正我)。因此,union数据类型也是一种多态性吗?

c++ - Boost Variant 本质上是 C/C++ 中的 union ?

我想知道c/c++中的BoostVariant和union数据类型之间有什么区别。我知道union数据类型占用相同的内存位置,并且内存区域中最大的数据类型占用使用的内存总量,例如unionspace{charCHAR;floatFLOAT;intINTEGER;}S;应该占用4个字节的内存,因为int和float是最大且相等的大小。BoostVariant和union数据类型在其他方面是否有相同点和不同点?我也知道BoostVariant可以采用任何数据类型,并且它允许数据类型“多态性”(如果我误用了OOP主题词,请纠正我)。因此,union数据类型也是一种多态性吗?

c++ - 将 optional 与 reference_wrapper 结合起来有意义吗?

我突然想到在C++中可以使用类型std::optional>.这种类型的对象本质上是对T类型对象的引用。或空值,即几乎是一个指针。我的问题:std::optional>之间有什么概念上的区别吗?和T*?有什么实际区别吗?是否存在建议选择std::optional>的情况?超过T*? 最佳答案 Isthereanyconceptualdifferencebetweenstd::optional>andT*?std::optional,正如名称已经暗示的那样,当我们可以有一个值或可能根本没有任何值时使用。对于T*相当于没有值(value

c++ - 将 optional 与 reference_wrapper 结合起来有意义吗?

我突然想到在C++中可以使用类型std::optional>.这种类型的对象本质上是对T类型对象的引用。或空值,即几乎是一个指针。我的问题:std::optional>之间有什么概念上的区别吗?和T*?有什么实际区别吗?是否存在建议选择std::optional>的情况?超过T*? 最佳答案 Isthereanyconceptualdifferencebetweenstd::optional>andT*?std::optional,正如名称已经暗示的那样,当我们可以有一个值或可能根本没有任何值时使用。对于T*相当于没有值(value

c++ - 为什么 `std::reference_wrapper` 秒内不能推导出模板实例?

假设我有一些T类型的对象,我想把它放到一个引用包装器中:inta=5,b=7;std::reference_wrapperp(a),q(b);//or"autop=std::ref(a)"现在我可以轻松地说if(p,因为引用包装器具有到其包装类型的转换。一切都很好,我可以像处理原始对象一样处理引用包装器的集合。(正如questionlinkedbelow所示,这可能是生成现有集合的替代View的有用方法,可以随意重新排列而不产生完整拷贝的成本,以及维护更新与原始集合的完整性。)但是,对于某些类,这不起作用:std::strings1="hello",s2="world";std::re

c++ - 为什么 `std::reference_wrapper` 秒内不能推导出模板实例?

假设我有一些T类型的对象,我想把它放到一个引用包装器中:inta=5,b=7;std::reference_wrapperp(a),q(b);//or"autop=std::ref(a)"现在我可以轻松地说if(p,因为引用包装器具有到其包装类型的转换。一切都很好,我可以像处理原始对象一样处理引用包装器的集合。(正如questionlinkedbelow所示,这可能是生成现有集合的替代View的有用方法,可以随意重新排列而不产生完整拷贝的成本,以及维护更新与原始集合的完整性。)但是,对于某些类,这不起作用:std::strings1="hello",s2="world";std::re

c++ - 为什么 boost::variant 不提供运算符 !=

给定两个相同的boost::variant实例a和b,允许使用表达式(a==b)。但是(a!=b)似乎未定义。这是为什么呢? 最佳答案 我认为它只是没有添加到库中。Boost.Operators并没有真正的帮助,因为任何一种变体都是从boost::operator::equality_comparable派生的。DavidPierre说你可以使用它是对的,但你的回答也是正确的,ADL找不到新的运算符!=,所以你需要一个using运算符。我会在boost-users邮件列表中问这个问题。编辑@AFoglia的评论:七个月后,我正在研究

c++ - 为什么 boost::variant 不提供运算符 !=

给定两个相同的boost::variant实例a和b,允许使用表达式(a==b)。但是(a!=b)似乎未定义。这是为什么呢? 最佳答案 我认为它只是没有添加到库中。Boost.Operators并没有真正的帮助,因为任何一种变体都是从boost::operator::equality_comparable派生的。DavidPierre说你可以使用它是对的,但你的回答也是正确的,ADL找不到新的运算符!=,所以你需要一个using运算符。我会在boost-users邮件列表中问这个问题。编辑@AFoglia的评论:七个月后,我正在研究

c++ - 为什么要为具有非平凡析构函数的类声明 constrexpr 构造函数(例如 unique_ptr、std::variant)

据我了解(至少对于c++14而言),析构函数不能是constexpr如果它不是微不足道的(隐式生成或=default)。声明constexpr有什么意义?具有非平凡析构函数的结构的构造函数?structX{inta_;constexprX(inta):a_{a}{}//constexpr~X(){};//Errordtorcannotbemarkedconstexpr//~X(){};//causeserroratydeclaration:temporaryofnon-literaltype‘X’//inaconstantexpression.};templatestructY{};i