草庐IT

typedef-name

全部标签

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++ - 编译错误 : `‘error_category’ does not name a type` with g++ 6. 3.0

我尝试编译这个C++/Python库https://bitbucket.org/fluiddyn/fluidfft如果安装了mpi4py,它运行良好。如果没有安装mpi4py,不使用MPI的代码无法编译。编译Cython文件时出现错误。错误很长,开始于:Infileincludedfrom/usr/include/c++/6/bits/ios_base.h:46:0,from/usr/include/c++/6/ios:42,from/usr/include/c++/6/ostream:38,from/usr/include/c++/6/iostream:39,fromsrc_cpp/

c++ - boost named_semaphore 示例?

我没能找到一个很好的例子来展示如何使用boost::interprocess::named_semaphore(甚至在Boost网站上也没有)。我可以看到一些关于interprocess_semaphore的东西,但它们似乎完全不同,我不知道为一个显示的内容是否也适用于另一个。任何人都可以给我一些指向此类示例/tutorials/documentation的链接吗?谢谢。 最佳答案 interprocess_semaphore和named_semaphore之间的主要区别在于interprocess_semaphore是通过使用共享

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++ - Qt错误: 'const class QString' has no member named 'toStdString'

我收到此错误error:'constclassQString'hasnomembernamed'toStdString'虽然QString有它。(link).代码std::stringMessage::toStdString()const{returnm_string.toStdString();} 最佳答案 直接从这里复制答案:HowtoconvertQStringtostd::string?QStringqs;//EitherthisifyouuseUTF-8anywherestd::stringutf8_text=qs.toU

c++ - 检测 typedef 的等价性

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

c++ - 模板别名 shared_ptr 和 unique_ptr 时是否有任何陷阱或限制?

为了减少输入类似内容的简单原因:std::shared_ptr;std::unique_ptr;每次想使用智能指针的时候,我就想到了使用模板别名:templateusingsptr=std::shared_ptr;templateusinguptr=std::unique_ptr;所以我可以像这样使用它们:sptr;uptr;假设我在自己的命名空间中保护它们,以这种方式使用带有shared/unique_ptr的模板别名是否有任何陷阱或限制?我会不会做一些我可以用直接模板语法做而我不能用别名做的事情?由于其他原因,这是一个坏主意吗? 最佳答案

c++ - 枚举类 : does not name a value error

我有enumclassErrorLevel{VERBOSE,DEBUG_,INFORMATION,WARNING,ERROR};这个有效:assertDetectionParameters(parameterSet,ErrorLevel::WARNING);这不是:assertDetectionParameters(parameterSet,ErrorLevel::ERROR);Error1errorC2589:'constant':illegaltokenonrightsideof'::'Error2errorC2059:syntaxerror:'::'Resharper说:"Err