E_g*_*E_g 3 c++ gcc nested forward-declaration dependent-type
(我知道这不是常规的实现,但是我想尝试一下。)
struct TrieNode {
std::unordered_map<char, TrieNode> next;
};
Run Code Online (Sandbox Code Playgroud)
此类已很好地编译,并且在Visual Studio 2017下可以按预期工作。但是,它不使用gcc(c ++ 14)进行编译(正如我期望的那样)。
Run Code Online (Sandbox Code Playgroud)In file included from /usr/include/c++/8/bits/stl_algobase.h:64, from /usr/include/c++/8/bits/char_traits.h:39, from /usr/include/c++/8/ios:40, from /usr/include/c++/8/ostream:38, from /usr/include/c++/8/iostream:39, from prog.cpp:1: /usr/include/c++/8/bits/stl_pair.h: In instantiation of ‘struct std::pair<const char, TrieNode>’: /usr/include/c++/8/bits/stl_vector.h:1610:27: required from ‘struct __gnu_cxx::__aligned_buffer<std::pair<const char, TrieNode> >’ /usr/include/c++/8/bits/hashtable_policy.h:234:43: required from ‘struct std::__detail::_Hash_node_value_base<std::pair<const char, TrieNode> >’ /usr/include/c++/8/bits/hashtable_policy.h:280:12: required from ‘struct std::__detail::_Hash_node<std::pair<const char, TrieNode>, false>’ /usr/include/c++/8/bits/hashtable_policy.h:2027:49: required from ‘struct std::__detail::_Hashtable_alloc<std::allocator<std::__detail::_Hash_node<std::pair<const char, TrieNode>, false> > >’ /usr/include/c++/8/bits/hashtable.h:173:11: required from ‘class std::_Hashtable<char, std::pair<const char, TrieNode>, std::allocator<std::pair<const char, TrieNode> >, std::__detail::_Select1st, std::equal_to<char>, std::hash<char>, std::__detail::_Mod_range_hashing, std::__detail::_Default_ranged_hash, std::__detail::_Prime_rehash_policy, std::__detail::_Hashtable_traits<false, false, true> >’ /usr/include/c++/8/bits/unordered_map.h:105:18: required from ‘class std::unordered_map<char, TrieNode>’ prog.cpp:9:37: required from here /usr/include/c++/8/bits/stl_pair.h:215:11: error: ‘std::pair<_T1, _T2>::second’ has incomplete type _T2 second; /// @c second is a copy of the second object ^~~~~~ prog.cpp:7:8: note: forward declaration of ‘struct TrieNode’ struct TrieNode { ^~~~~~~~
我想知道可视化c ++实现没有什么问题吗?对于这种情况,标准怎么说?
我无法告诉您为什么它在MSVS2017中起作用,但是按照标准,使用不完整的类型与是不确定的行为std::unordered_map。一个类的完整类上下文由[class.mem] / 6定义为
一个类的完整类上下文是
函数体([dcl.fct.def.general]),
默认参数
noexcept-specifier([except.spec]),或
默认成员初始化器
仅在那些地方,类名表示完整的类型。由于我们不在任何地方,因此名称命名为不完整的类型。如果我们检查是否可以使用它,std::unordered_map请检查[res.on.functions] / 2,
特别是在以下情况下,效果不确定:[...]
- 实例化模板组件或评估概念时,如果将不完整的类型([basic.types])用作模板参数,除非该组件特别允许。
因此,通常这是不允许的。我们需要检查[container.requirements]和[unord.map],但其中没有任何内容表明允许使用不完整的类型。这意味着我们会退回到一般规则,这是不允许的。
| 归档时间: |
|
| 查看次数: |
69 次 |
| 最近记录: |