草庐IT

Duck-typing

全部标签

c++ - C++ 中的 "error: Expected a type, got ' 类名 '"

使用以下代码:templateclassnode{[...]};classb_graph{friendistream&operator>>(istream&in,b_graph&ingraph);friendostream&operatorvertices;//Thisline我得到:error:type/valuemismatchatargument1intemplateparameterlistfor‘templateclassstd::vector’error:expectedatype,got'node'error:templateargument2isinvalid在指示的行

c++ - 为什么 boost::call_traits<T>::param_type 是枚举类型的引用?

基本的C++03枚举类型只是一个具有奇特名称的整数值,因此我希望按值传递它....出于这个原因,我还期望boost::call_traits::param_type与T=SomeEnum确定最有效的传球方式T是按值(value)。从boost文档中查看CallTraits:Definesatypethatrepresentsthe"best"waytopassaparameteroftypeTtoafunction.当我使用boost::call_traits::param_type时与T=SomeEnum它确定SomeEnum应该通过引用传递。我也期待C++11classenums也

c++ - 文章 Generic<Programming> Typed Buffers 在 C++ 11 中是否完全过时?

我正在阅读GenericTypedBuffers,一篇来自AndreiAlexandrescu的相当古老的文章。我想知道它是否仍然有意义。在他的文章中,Alexandrescu指出了当性能至关重要时std::vector的一些问题:分配vector时不必要的数据初始化,我认为可以使用std::vector::reserve解决使用C++11和移动语义解决的昂贵移动操作大多数编译器不会通过使用std::memcpy和std为char等类型优化std::vector::memmove。现在对于主流编译器来说这是不正确的(据我所见)。指数级增长。您无法通过简单的方法调用来缩小std::vec

c++ - 未找到 difference_type

当我尝试使用std::distance时使用gcc4.7下的自定义迭代器,它提示找不到difference_type.遗憾的是,我不知道为什么会失败。#includeclassnit{public:typedefintdifference_type;};intmain(){constnittest1;std::distance(test1,test1);return0;}给出错误:/usr/include/c++/4.7/bits/stl_iterator_base_funcs.h:114:5:error:notypenamed‘difference_type’in‘structstd

c++ - 如何确定 std::type_index 是否对我的编译器是唯一的?

标准是否规定std::type_index(typeid(obj))的调用对于该类型是唯一的?我找不到这方面的信息。从type_info::name()我得到了这个:Returnsanimplementationdefinednull-terminatedcharacterstringcontainingthenameofthetype.Noguaranteesaregiven,inparticular,thereturnedstringcanbeidenticalforseveraltypesandchangebetweeninvocationsofthesameprogram.(来

c++ - 为什么 type_info::name() 未指定?

我完全知道std::type_info::name()的返回值是实现定义的。来自C++标准(ISO/IEC14882:2003§18.5.1.7):Returns:animplementation-definedNTBS.我的问题是:为什么?如果标准规定了返回值应该是什么,这个成员函数不是更有用吗? 最佳答案 基本上,如果一个实现决定他们不能或不想支持RTTI,他们可以return"";。如果标准强制它返回某些东西,他们可能会扼杀任何为RTTI资源不存在或想要禁用的环境(例如微芯片)提供兼容编译器的能力。别忘了我们不想在任何编译器上

C++ : how do I use type_traits to determine if a class is trivial?

在C++0x中,我想确定一个类是否简单/是否具有标准布局,以便我可以使用memcpy()、memset()等...我应该如何使用type_traits实现下面的代码,这样我才能确认一个类型是微不足道的?templateboolisTrivialType(){boolisTrivial=???returnisTrivial;}注意:is_pod()限制太多:我希望我的类有简单的构造函数等......为了方便。补充:我认为std::is_standard_layout可能会给我我正在寻找的东西。1.如果我添加构造函数,它仍然返回true2.如果我添加一个虚方法,它返回false这是我需要确

c++ - 如何使用 type_traits 检测字符串文字?

我如何可靠地对任何不是字符串文字的内容进行static_assert?例如,在下面的代码中,我试图包装标准断言宏,但静态拒绝消息的任何不是字符串文字的内容(因为当断言触发时,除了字符串文字之外的任何内容都不会在运行时显示).#include#include#include#definemy_assert(test,message)\static_assert(\(\!std::is_pointer::value&&\!std::is_array::value\),\"literalstringrequired"\);\assert((message,(test)));intmain()

c++ - 函数参数中的 `type_alias<char[N]>{}` VS `char[N]{}`

环境:x86-64Clang6.0.0函数的定义:voidfoo(constchar*){}foo(char[16]{});//houston,thereisaproblem!foo(type_alias{});//compilehappilytype_alias很简单:templateusingtype_alias=T;livedemon作为注释,case1case2时无法编译能够。我知道aliasdeclarations与using不是文本替换(如#define),它是该类型的同义词。但我仍然不知道如何解释这种情况。然后我给GCC一个try:prog.cc:Infunction'i

c++ - Clang claims that `member reference base type ' X' is not a structure or union`,但 X 是具有推导参数的结构模板

考虑以下代码:templatestructX{X(T){}voidfoo(){}};templatestructY{intobject=0;voidbar(){X(object).foo();}};Liveongcc.godbold.orgGCC8.2编译它,而Clang7吐出以下错误::13:18:error:memberreferencebasetype'X'isnotastructureorunionX(object).foo();~~~~~~~~~^~~~这对我来说像是一个错误。条件非常具体:如果任一结构不是模板,或者object不是成员变量,或者不涉及CTAD(类模板参数推导