草庐IT

type-equivalence

全部标签

C++ 模板 : Select different type based on value of template parameter

如何在C++中完成以下操作,这些事情叫什么?templateclassNuclearPowerplantControllerFactoryProviderFactory{//ifS==truetypedefintdata_t;//ifS==falsetypedefunsignedintdata_t;}; 最佳答案 按特化:templateclassFoo;templateclassFoo{typedefintdata_t;};templateclassFoo{typedefunsignedintdata_t;};您可以选择将这两种情

C++:错误 "... is not derived from type ..."

templateclassBimap{public:classData;typedefData*DataP;typedefstd::multimapT1Map;typedefstd::multimapT2Map;classData{private:Bimap&bimap;T1Map::iteratorit1;/*...*/};};这给了我这个编译错误:error:type'std::multimap::Data*,std::less,std::allocator::Data*>>>'isnotderivedfromtype'Bimap::Data'这是什么意思?这里有什么问题?

C++:错误 "... is not derived from type ..."

templateclassBimap{public:classData;typedefData*DataP;typedefstd::multimapT1Map;typedefstd::multimapT2Map;classData{private:Bimap&bimap;T1Map::iteratorit1;/*...*/};};这给了我这个编译错误:error:type'std::multimap::Data*,std::less,std::allocator::Data*>>>'isnotderivedfromtype'Bimap::Data'这是什么意思?这里有什么问题?

C++ 错误 : 'unordered_map' does not name a type

据我所知,我所做的一切都是正确的,并且我收到了错误消息:error:'unordered_map'doesnotnameatypeerror:'mymap'doesnotnameatype在我的代码中,我有:#includeusingnamespacestd;//globalvariableunordered_mapmymap;mymap.reserve(7000);voidmain{return;}我看不出这里可能缺少什么......编辑:当我将声明更新为std::tr1::unordered_mapmymap;我能够消除第一个错误,但是当我尝试保留时,我仍然收到第二个错误消息。ED

C++ 错误 : 'unordered_map' does not name a type

据我所知,我所做的一切都是正确的,并且我收到了错误消息:error:'unordered_map'doesnotnameatypeerror:'mymap'doesnotnameatype在我的代码中,我有:#includeusingnamespacestd;//globalvariableunordered_mapmymap;mymap.reserve(7000);voidmain{return;}我看不出这里可能缺少什么......编辑:当我将声明更新为std::tr1::unordered_mapmymap;我能够消除第一个错误,但是当我尝试保留时,我仍然收到第二个错误消息。ED

c++ - C++ 中的 "Y does not name a type"错误

我不知道要搜索什么才能找到对此的解释,所以我问。我有这个报告错误的代码:structSettings{intwidth;intheight;}settings;settings.width=800;//'settings'doesnotnameatypeerrorsettings.height=600;//'settings'doesnotnameatypeerrorintmain(){cout但如果我将值赋值放在main中,它会起作用:structSettings{intwidth;intheight;}settings;main(){settings.width=800;//noe

c++ - C++ 中的 "Y does not name a type"错误

我不知道要搜索什么才能找到对此的解释,所以我问。我有这个报告错误的代码:structSettings{intwidth;intheight;}settings;settings.width=800;//'settings'doesnotnameatypeerrorsettings.height=600;//'settings'doesnotnameatypeerrorintmain(){cout但如果我将值赋值放在main中,它会起作用:structSettings{intwidth;intheight;}settings;main(){settings.width=800;//noe

c++ - 为什么 cppreference 将 type_traits xxx_v 快捷方式定义为内联 constexpr 而不仅仅是 constexpr?

为什么cppreference将type_traitsxxx_v快捷方式定义为inlineconstexpr而不仅仅是constexpr?例如,参见is_integral_v:templateinlineconstexprboolis_integral_v=is_integral::value;这只是风格问题还是行为上有一些差异?据我所知constexpr变量是隐式inline.编辑:查看最新标准的草案,它也使用inlineconstexpr。那么这个问题实际上适用于标准。 最佳答案 [dcl.constexpr]/9Aconste

c++ - 为什么 cppreference 将 type_traits xxx_v 快捷方式定义为内联 constexpr 而不仅仅是 constexpr?

为什么cppreference将type_traitsxxx_v快捷方式定义为inlineconstexpr而不仅仅是constexpr?例如,参见is_integral_v:templateinlineconstexprboolis_integral_v=is_integral::value;这只是风格问题还是行为上有一些差异?据我所知constexpr变量是隐式inline.编辑:查看最新标准的草案,它也使用inlineconstexpr。那么这个问题实际上适用于标准。 最佳答案 [dcl.constexpr]/9Aconste

C++11 : Are there reasons why some Regular Types should not have `std::hash` specialised?

对于常规类型,我的意思是编程元素中Stepanov的定义,基本上,有相等的概念,并且相互复制的对象比较相等。所以当你有一个常规类型T,并且等式关系是传递的(a==b&&b==c=>a==c),可以定义一个(non-trivial)散列函数这与相等的定义一致(a==b=>h(a)==h(b))。总是。但标准中并没有很多std::hash专业。例如。std::complex没有,容器也没有,vector除外。和bitset.所以我想知道这里的设计原则是什么。或者,换个方式问:有理由不提供std::hash您自己的类型的特化,只要它们是常规的并且相等是可传递的?