草庐IT

pseudo-typedef

全部标签

c++ - std::function 参数列表和 typedef

我有一个类似这样的typedef:typedefstd::functionMyFunction;在我的代码中某处是这样使用的:MyFunctionfunc=[](intarg1,floatarg2){/*dosometing*/};问题是,每次我更改函数的参数数量(例如,我添加第三个参数chararg3)时,我都被迫在我使用MyFunction的所有代码中更新它(即使这些根本不使用参数。而且我懒得那样做。有没有办法从它的类型中获取std::function的参数列表?(我的意思是)这样函数创建看起来像那样?:MyFunctionfunc=[](MyFunction::args){/*d

c++ - Boost graph typedef c++ 结构的前向声明

简短的问题描述:基本上我想要structType;typedefcontainerMyType;structType{MyType::sometypemember;}现在,我该怎么做?实际问题:对于BoostSuccesiveShortestPath算法,我需要将我的前向边缘映射到它们的反向。我有以下代码:structVertexProperty{};structEdgeProperty;typedefboost::adjacency_listDirectedGraph;structEdgeProperty{doubleedge_capacity;//capacity:1forforw

c++ - 如何从对象实例中获取成员 typedef

在MSVC2010中给出如下代码:错误C2039:“my_type”:不是“全局命名空间”的成员templateclassC{public:typedefTmy_type;};Cc;autof=[&c](){decltype(c)::my_typev2;//ERRORC2039};我找到了一个蹩脚的方法来解决它,但我想知道当你只有一个对象实例时获取typedef的正确方法是什么。 最佳答案 从一堆非常有用的评论中,我得到了一个可行的解决方案。感谢大家。remove_reference作为身份对象具有双重用途。templateclas

c++ - 模板的 typedef 包括 char[][] - 适用于 VS2008 但不适用于 gcc

我有一些正在使用的库代码。它在VisualStudio(2008)下编译和工作,但不是GCC(v4.8.4.)在标题中我们有:externconstcharmenu_styles[MENU_COUNT][MAX_LEN];typedefSysEnumMenuStyleEnum;SysEnum在哪里(在另一个文件中定义):templateclassSysEnumgcc遇到错误:error:‘menu_styles’cannotappearinaconstant-expression我完全同意。(此外,它是constchar*转换为char*)。我希望VS2008只是用constchar*

c++ - 转发声明可能的 typedef c++0x

我从Forwarddeclareaclass'spublictypedefinc++这个问题的答案中了解到,在C++中前向声明可能是typedef的东西是不可能的。是否可以在C++0x中完成此问题的要求?否则,进行如下更改:classX{...};typedefXZ;到classY{...};typedefYZ;破坏客户端代码。我认为不应该这样,因为typedef的要点是它们应该使底层类型对客户端透明,因此您可以在不破坏客户端代码的情况下更改实现。澄清基本上,假设我们有这两个选项:classX{...};typedefXZ;//(1)或classZ{...};//(2)我希望能够在客户

c++ - 从模板化父访问子 typedef

为什么下面的不编译?templatestructBase{typenameChild::Typet;//Doesnotcompile."NotypenamedTypeinChild"};structDerived:publicBase{typedefintType;};为什么Base无法访问其子类型?我用静态函数而不是typedef尝试了同样的方法,效果很好。我尝试了GCC4.4.2和clang3.0。 最佳答案 这种代码将无法工作,因为在实例化Base时Derived尚未完全定义。它基本上是一个不完整的类型。备选方案可以从简单到非

c++ - 重载 typedef 参数

这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Overloadingmembermethodswithtypedefaliasesasparameters我有以下方法voidsetField(charx);和另一个重载方法voidsetField(int8_tx);这会在除solaris以外的所有平台上编译,在solaris上int8_t是typedefaschar有什么办法可以解决这个问题,因为我不想更改方法的名称我收到编译器错误提示methodalreadyexists

c++ - 检测 typedef 的等价性

在我的应用程序中,我有一个类型负责(可能)涉及大量数字的计算,还有一个类型用于处理器之间的通信。typedefMyBigIntegerClassbigInt;typedefintsmallInt;通信部分与MyBigIntegerClass不兼容,因此在通信之前,例如bigInts的vector,它必须转换为smallints。到目前为止,完全没有问题。但是,对于大多数问题实例,没有必要使用MyBigIntegerClass。事实上,即使int32_t也足够了。这就是为什么我允许这样的配置typedefint32_tbigInt;typedefint16_tsmallInt;bigIn

c++ - 是否可以使用强制编译器错误扩展 typedef?

我一直在使用下面显示的方法来强制编译器对我大喊一个变量类型:templatestructshow_type;将它与所需的变量一起使用,这样编译器就会错误地给出一个不完整的结构类型:typedefint32_ts32;s32a;show_type();因此GCC5.3.0产生错误:invaliduseofincompletetype'structshow_type'和MSVC2015:'show_type':noappropriatedefaultconstructoravailable现在我想知道是否有办法强制错误显示typedef的完整层次结构s(即s32->int32_t->int

带有概念的 C++ 别名模板(typedef)?

http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2015/n4553.pdfgcc6:-f概念templateconceptboolString=requires(Ts){{s.clear()}->void;//etc.};voidprint(constString&message);//voidprint(Strmessage);//IwantStr=constString&voidtest(){std::stringstr;print(str);}有没有办法将Str声明为constString&? 最