使用类作为模板参数在其自身的延迟中
Using a class as template parameter in its own decleration
(我知道这不是一个传统的实现,但我想尝试一下这个想法。
struct TrieNode {
std::unordered_map<char, TrieNode> next;
};
这个类在Visual Studio 2017下编译得非常好,并按预期工作。但是,它不能使用 gcc (c++14( 编译(正如我所期望的那样(。
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],但其中没有任何内容表明允许不完整的类型。 这意味着我们回到一般规则,这是不允许的。
相关文章:
- 如何反转整数参数包
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 如何使用默认参数等选择模板专业化
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 函数调用中参数的顺序重要吗
- 部分定义/别名模板模板参数
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- 使用不带参数的函数访问结构元素
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 如何仅为一个函数添加延迟
- 使用类作为模板参数在其自身的延迟中
- 使用 lambda 和可变参数模板延迟初始化对象 - 任意传递值
- 函数参数的延迟销毁
- 使用类作为具有正向延迟的 STL 类的模板参数
- 可变参数模板类,用于对可变参数模板函数进行延迟调用
- 延迟函数调用,如何传递参数