gcc7的std::变体实现中的Bug
Bug in std::variant implementation of gcc7
考虑以下代码:
#include <variant>
constexpr auto cc = 'c';
constexpr std::variant<const int*,const char*> pp{&cc}; // passes
constexpr std::variant<const int&,const char&> rr{cc}; // FAILS ?!
对于g++ (GCC) 7.0.0 20161023 (experimental)
,最后一行失败,错误消息:
variant|199 col 9| error: call to non-constexpr function ‘void* operator new(std::size_t, void*)’
|| { ::new (&_M_storage) _Type(std::forward<_Args>(__args)...); }
指向构造函数
template<typename... _Args>
constexpr _Uninitialized(in_place_index_t<0>, _Args&&... __args)
: _M_storage{} // This was added manually
{ ::new (&_M_storage) _Type(std::forward<_Args>(__args)...); }
实际上,在此之前还有两个问题:
首先它是抱怨call to non-constexpr function ‘std::_Enable_default_constructor<false, _Tag>::_Enable_default_constructor(std::_Enable_default_constructor_tag)
,我已经通过使constexpr
构造器_Enable_default_constructor<false, _Tag>::_Enable_default_constructor(_Enable_default_constructor_tag) { }
修复了它
然后它抱怨_M_storage’ must be initialized by mem-initializer in ‘constexpr’ constuctor
,我通过将: _M_storage{}
添加到成员初始化列表来修复它,尽管我认为它不应该抱怨,因为添加的行应该隐式生成。
那么第一个问题是:这肯定是个bug,对吧?
第二个问题是:在gcc修复它之前,我如何通过更改库代码来解决它?
通过不允许引用作为变体替代(目前),在标准中"固定"了这一点。从2017-03-29开始的GCC 7.0.1的快照似乎可以正确地完成。
相关文章:
- 如果没有malloc,链表实现将失败
- 如何在c++中实现处理器调度模拟器
- 如何在c++中使用引用实现类似python的行为
- 实现无开销push_back的最佳方法是什么
- 使用简单类型列表实现的指数编译时间.为什么
- 如何在BST的这个简单递归实现中消除警告
- 实现一个在集合上迭代的模板函数
- 我应该实现右值推送功能吗?我应该使用std::move吗
- Clang bug?使用指针作为模板参数
- 如何正确实现和访问运算符的各种自定义枚举器
- C++Union/Struct位域的实现和可移植性
- 这个极客对极客的trie实现是否存在内存泄漏问题
- 在c++中实现LinkedList时,应出现未处理的错误
- 为左值和右值的包装器实现C++范围
- 使用模板进行堆栈实现; "name followed by :: must be a class or namespace"
- 使用GSoap实现ONVIF
- 在用于格式4的arm模拟器中实现功能时的一个问题
- 用于AVX的ln(x)的实现,m256
- gcc7的std::变体实现中的Bug
- 我的展开树实现中出现了奇怪的bug