草庐IT

typedeffing

全部标签

c++ - 在 C++ 中使用函数 typedef 定义函数

我正在Windows中实现一项服务。VisualStudio2012具有以下函数typedef:typedefVOIDWINAPISERVICE_MAIN_FUNCTIONW(DWORDdwNumServicesArgs,LPWSTR*lpServiceArgVectors);还有一个函数指针typedef:typedefVOID(WINAPI*LPSERVICE_MAIN_FUNCTIONW)(DWORDdwNumServicesArgs,LPWSTR*lpServiceArgVectors);如何使用typedef定义具有此函数签名的函数? 最佳答案

c++ - typedef 有效, 'using =' 无效

我有一段代码,稍微简化一下,相当于以下编译和工作正常的代码。templatestructfactory_function{typedeffunction(Args...)>type;};templateshared_ptrcreate_function(Args...args){returnmake_shared(args...);}templateintregister_factory(identifierid,typenamefactory_function::typefactory){}intmain(intargc,char*argv[]){register_factory(1

c++ - 如何转发声明我将使用 typedef 创建的类型?

例如,拿这段代码:classFoo;classSomething{Foo*thing;};typedefstd::vectorFoo;这不会编译,因为Foo当typedef时已经是一个类型被击中。但是,我认为它显示了我的用例;我有周期性依赖关系,需要一个来满足另一个,但(目前)其中一件事是typedef。我不想写类似的东西classFoo{std::vectorinside;}因为那时我需要记住inside在每个my_foo.inside.some_method().我还想避免围绕std::vector编写包装器,因为它会有很多样板文件。我如何转发声明我用typedef定义的类型?或者

c++ - 指向类型不完整的 typedef 的指针

有什么方法可以声明一个指向不完整类型的指针,该类型将由实现中的typedef设置?这是我想要的例子:#ifndefTEST_H#defineTEST_Hnamespacestd{classstring;//THISWON'TWORK!}structTest{std::string*value;};#endifstring是basic_string的类型定义,因此示例中的代码将不起作用。我可以声明一个不完整类型的std::basic_string,但这看起来像是一种解决方法。我知道编译器不会为typedef生成符号,对于不同文件中的不同类型,可能会在typedef中使用相同的名称。但由于

c++ - 用同名的 typedef 替换预处理器宏

我想用同名的正确typedef替换宏。我有#defineFooTypechar*在第三方库中,这破坏了我的一些代码(更准确地说:一些我被迫使用的代码,我自己无法更改)。我想用同名的typedef替换它,然后用#undef宏替换它。我试过类似的东西:#defineTMP_MACROFooType#undefFooTypetypedefTMP_MACROFooType;#undefTMP_MACRO但是预处理器将其扩展为:typedefFooTypeFooType;(至少g++-E是这么告诉我的)。所以宏TMP_MACRO不会立即展开。由于“FooType”不存在,因此无法编译。如何用适当

c++ - 在实现文件中使用 typedef 来缩短类型签名的负面后果是什么?

我正在用C++做我的第一个真正的项目,它是一个简单的CSV解析器(目前处于非常早期的阶段),我在头文件中有以下内容:classCsvReader{public://ActionstocommitoneachiterationoftheCSVparserenumAction{ADD_CHAR,ADD_FIELD,NONE};//ThepossiblestatesforeachcellofaCSVenumState{START,IN_FIELD,IN_QUOTED_FIELD,IN_QUOTED_QUOTE};//CreatethereaderfromafileexplicitCsvRea

c++ - 转发声明 typedef 的结构

我不知道如何转发声明一个windows结构。定义是typedefstruct_CONTEXT{....}CONTEXT,*PCONTEXT我真的不想进入这个标题,因为它无处不在。我试过了结构语境和结构_CONTEXT运气不好(用winnt.h中的实际结构重新定义基本类型。 最佳答案 extern"C"{typedefstruct_CONTEXTCONTEXT,*PCONTEXT;}您需要声明_CONTEXT是一个struct。并将其声明为extern"C"以匹配windows.h的外部链接(这是一个C头文件)。但是,您不需要为typ

c++ - typedef 中的 const 警告

当我使用icc11编译C++程序时,它给出了这个警告:warning#21:typequalifiersaremeaninglessinthisdeclarationtypedefconstdirection_vector_ref_tdirection_vector_cref_t;它说const只是毫无意义。我对此很好奇,因为如果这个typedef展开它会变成constarray&和const绝对有意义。为什么会发出这个警告? 最佳答案 direction_vector_ref_t,我认为它是一个引用。引用在设计上是const的,因

c++ - 我可以使用类级别的 typedef 作为基类的模板参数吗?

假设一个模板化的基类:templateclassBaseClass;在其他类中,我想从中继承,其中T是一个相当复杂的类型,所以我想使用typedef。因为我不想污染命名空间,所以我希望在类定义中包含typedef:classChildClass:publicBaseClass{typedefMyVeryVeryComplicatedTypeLocalType;...}现在当然我还不能使用LocalType作为BaseClass的模板参数并且必须写两次复杂的定义(MyVeryVeryComplicatedType)。(所以我猜标题问题的答案是“否”。)问题:有没有办法只定义一次,但仍然只

c++ - 无法将 const 应用于 typedef 引用

以下代码在将const应用于value_type&的返回值引用时有效,但如果我使用相同类型的typedef,则会出错。举个例子:classT{};classA{public:typedefTvalue_type;typedefvalue_type&reference;//Notworkingconstreferenceoperator*()const;//Butthisworks?//constvalue_type&operator*()const;};//Error!consttypenameA::referenceA::operator*()const{}intmain(){ret