草庐IT

typedef-name

全部标签

c++ - 了解空继承类的未使用 typedef

我只是想了解我正在阅读的一些教程代码。我正在尝试学习一些Dx11代码,我正在学习的教程中包含设计为事件详细信息的类,以便在事件发生时传递给函数,例如鼠标按钮被按下。有一个空的基类EventArgs定义如下:classEventArgs{public:EventArgs(){};}这是由其他事件类继承的。因此,例如,他们有一个按键事件参数类,如下所示:classKeyEventArgs:publicEventArgs{public:typedefEventArgsbase;KeyEventArgs(/**/){}//Restoftheclass}我理解所有事件都继承一个基础来表示“它们是

c++ - Typedef、Ruby 和 SWIG

我正在尝试为某些C++类生成Ruby包装器。生成成功,所有的方法都创建了,但是问题是很多C++的方法都是这样用的:#ifdefUSE_LONGLONG_COUNTStypedefunsignedlonglongCount;/*acountofsomething*/#elsetypedefunsignedlongCount;/*acountofsomething*/#endif当我在irb中运行一个返回计数的方法时,我得到如下信息:irb(main):006:0>ngram.numNgrams(0)=>#我期待一个数字...我尝试使用反射来查看我是否能以某种方式获得该值,但没有雪茄。有什

c++ - 具有多个输出的 Typedef

我刚刚发现以下是有效的C++typedefconstchar*PSTR,*LPSTR;我的问题是:PSTR和LPSTR是同一个别名吗?为什么我把它改成typedefconstchar*PSTR,LPSTR;我知道LPSTR是一个字符?? 最佳答案 这就是为什么我总是将*贴在名称上而不是类型上。当你输入时typedefconstchar*PSTR;你必须读到*PSTR是一个constchar,所以PSTR是一个constchar的地址>.所以如果你输入typedefconstchar*PSTR,*LPSTR,OTHER;OTHER和*

c++ - 带有自定义删除器的 std::shared_ptr 的 Typedef 别名

我想为std::shared_ptr创建别名使用自定义删除器。此代码有效,但仅适用于唯一指针。我收到有关标有[1]的行的无效模板参数数量的错误。我注意到std::unique_ptr的模板和ctor参数和std::shared_ptr与所列不同here和here我注意到这个问题可能与this重复,但我不知道如何解决我的问题#include#includetemplatestructDeleter{voidoperator()(T*p)constnoexcept{p->Drop();//SFINAE};};templateusingmy_unique_ptr=std::unique_pt

c++ - 如何使 exuberant-ctags 解析 "using"样式的 typedef?

如何让ctags解析using类型别名,如下所示?usingFooPtr=std::shared_ptr;它只选取那些用typedef声明的。 最佳答案 从Exuberant-ctags派生的Universal-ctags(https://ctags.io)在C++源文件中处理“使用”:[jet@localhost]/tmp%cat/tmp/foo.cppusingFooPtr=std::shared_ptr;[jet@localhost]/tmp%u-ctags-o-/tmp/foo.cppFooPtr/tmp/foo.cpp/^

c++ - 出于对象替换的目的,对象的 "name"究竟是由什么构成的?

根据[basic.life]/8,If,afterthelifetimeofanobjecthasendedandbeforethestoragewhichtheobjectoccupiedisreusedorreleased,anewobjectiscreatedatthestoragelocationwhichtheoriginalobjectoccupied,apointerthatpointedtotheoriginalobject,areferencethatreferredtotheoriginalobject,orthenameoftheoriginalobjectwil

C++——typedef "inside"模板参数?

假设我有一个这样的模板函数:templatevoidmyfunc(Iteratora,typenameIterator::value_typeb){...}有没有办法通过为Iterator::valuetype声明一个typedef来实现同样的事情,我可以在函数签名中使用它?例如,我希望能够做这样的事情:templatevoidmyfunc(Iteratora,typeb){...}到目前为止,我已经求助于使用默认模板参数和Boost概念检查来确保始终使用默认值:templatevoidmyfunc(Iteratora,typeb){BOOST_STATIC_ASSERT((boost

c++ - 有没有办法使用 boost::program_options::parse_config_file 在 INI 文件中包含多个 "name=value"行?

我希望能够使用boost::program_options在INI文件中指定多个name=value行。有点像[list.names]name=valuename=value2name=value3有没有办法用boost::program_options实现这个?如果我尝试它,我会得到一个多次出现的错误如果没有,还有哪些其他库可用? 最佳答案 指定字段的值为std::vector在options_description:namespacepo=boost::program_options;po::options_descriptio

c++ - 函数参数中的 Typedef 等价

如果没有例子,这个问题很难问,所以这里是:#includestructO{};structC{templatevoidfunction1(void(C::*callback)(constO*));templatevoidfunction2(void(C::*callback)(consttypenameT::value_type));voidprint(constO*);};intmain(){Cc;c.function1>(&C::print);//Success.c.function2>(&C::print);//Fail.}我得到的错误是:error:nomatchingfunc

c++ - 不同头文件中跨相同命名空间的 typedef

我目前正在学习C++并且正在努力编写一些代码:花园.h:#ifndefGARDEN_H_#defineGARDEN_H_#include#include#include"Shape.h"#include"Utils.h"namespacecma{typedefboost::shared_ptrShapePtr;typedefstd::vectorGardenPlan;}#endif/*GARDEN_H_*/实用程序.h:#ifndefUTILS_H_#defineUTILS_H_#include"Garden.h"namespacecma{voidprintList(GardenPla