草庐IT

argument_types

全部标签

c++ - 检测某些非数字类型 T 的 std::numeric::type<T> 的特化

我想检查一个类型是否在std::numeric_limits中有一个条目。当类型是一个数组时——(或者可能不是一个数字?)我得到一个编译器错误。这使我无法根据std::numeric_limits是否支持该类型来检测和分支。如果有人愿意分享任何见解,我将不胜感激。//thefollowingprovokescompilererroronClang//Functioncannotreturnarraytype'type'(aka'char[20]')static_assert(!std::numeric_limits::is_specialized,"!std::numeric_limi

c++ - 无法使用自动参数化 true_type 检测 T::value()

使用SFINAE,has_value_int和has_value_auto两者都尝试检测类T是否有一个staticconstexpr名为value的函数.使用int参数化true_type,has_value_int效劳于演示类(class)pass和fail.使用auto参数化true_type,has_value_auto总是返回false。使用int有什么区别?并使用auto,为什么auto不工作?具体来说,为什么重载决策更喜欢match_auto(...)至match_auto(int)?#includeusingnamespacestd;//parametrizetrue_t

c++ - 玩弄 for arguments

灵感来自this.假设我们有一个非空的std::vectorv;有什么区别吗for(inti=v.size()-1;i>=0;i--){///Stuff.}和:for(inti=v.size();i--;){///Stuff.}?我的意思是,为了可读性我不会那样做,但谁知道什么对生活有用......(Here只是一个测试,看看它们是等价的)编辑:重点是i作为向后访问vector的索引(在索引比迭代器更可取的情况下)编辑2:出于好奇:他们最终得到了略微不同的汇编代码。参见this和this. 最佳答案 人们可以想到for循环for(;

c++ - 是否可以根据type_info创建对象?

差不多就是标题:可以根据type_info创建对象吗?这样做的目的是推迟对象的创建。例如,这是原始的“未延迟”代码:Foo*a=newFoo();Bar*b=newBar();这是延迟的://Storetypeindicesintoavectorstd::vectortypes;types.push_back(std::type_index(typeid(Foo)));types.push_back(std::type_index(typeid(Bar)));//Iteratethroughvector,createobjects?Isitpossible?如果这不可能,是否有任何其他

c++ - 在模板参数中使用时,type_trait<T>{} 中的 {} 的作用是什么?

我经常在模板代码中看到此{}的出现。我不确定我明白它在做什么。例如:std::enable_if_t{}&&!std::is_same{}>>这里的{}是什么?它是在实例化类型吗?模板参数是什么意思?据我所知,实例化一个类型意味着创建一个对象。您如何在这种情况下创建对象?它只是创建一个虚拟对象吗?为什么要这样做?这样做的意义和目的是什么? 最佳答案 在这种情况下,type_trait{}相当于type_trait::value.您的示例等效于以下内容:std::enable_if_t::value&&!std::is_same::v

c++ - "Class type redefinition"头文件和源文件之间的错误

所以我遇到了一个问题,我确信有一个非常明显的解决方案,但我似乎无法弄清楚。基本上,当我尝试在我的头文件中进行类定义并在我的源文件中进行实现时,我收到一条错误消息,提示我正在重新定义我的类。使用VisualC++2010Express。确切错误:“错误C2011:‘节点’:‘类’类型重新定义”示例代码如下:节点.h:#ifndefNODE_H#defineNODE_H#includeclassNode{public:Node();Node*getLC();Node*getRC();private:Node*leftChild;Node*rightChild;};#endif节点.cpp:

Content-Type:application/x-msexecl;是干什么的?底层原理是什么?

Content-Type:application/vnd.ms-excel是用于设置HTTP响应头中的Content-Type字段,指定返回的内容类型为MicrosoftExcel文件(.xls)。Content-Type是HTTP协议中的一个字段,用于指定传输的数据的类型和格式。通过设置Content-Type头部字段,服务器可以告知客户端接收到的数据的类型,以便客户端正确处理和解析数据。application/vnd.ms-excel是指定MicrosoftExcel文件类型的MIME类型。MIME(MultipurposeInternetMailExtensions)是一种标准化的数据格

c++ - "unspecialized class template can' t be used as a template argument”是什么意思?

我有一个名为AbstractRManagers的类,我想从一个单例模板类Singleton继承,但是abstractRmanager需要成为一个模板类我遇到了一些没有用的奇怪错误代码,我已经尝试查找它但是没运气。templateclassAbstractRManagers:publicSingleton{errorC3203:'AbstractRManagers':unspecializedclasstemplatecan'tbeusedasatemplateargumentfortemplateparameter'Type',expectedarealtype

c++ - 尝试与 typedef 交 friend 时出现 "elaborated type refers to typedef"错误

假设我有以下代码(一个简单的CRTP类层次结构)。我想对基类类型进行typedef以节省自己的输入(在我的实际代码中,我多次使用基类类型并且基类采用多个模板参数),并且我需要与基类交friend,因为我想保留实现私有(private)。templateclassBase{public:voidfoo(){*static_cast(this)->foo_i();}};templateclassDerived:publicBase>{public:typedefclassBase>BaseType;private://Thishereistheoffendinglinefriendclas

c++ - auto 的编译器问题?错误 : in a declarator-list 'auto' must always deduce to the same type

std::vectorvec;autoi=vec.begin(),j=std::next(i);Error:inadeclarator-list'auto'mustalwaysdeducetothesametype 最佳答案 在Linux上的g++中编译良好,因此它似乎是一个编译器错误。Probablythisone. 关于c++-auto的编译器问题?错误:inadeclarator-list'auto'mustalwaysdeducetothesametype,我们在StackOve