草庐IT

static成员

全部标签

c++ - "static functions with block scope are illegal"错误取决于初始化样式?

我有一个类Library,其中包含一个结构Transaction,该结构有一个类型为Patron的成员变量。classPatron{public:Patron(){}};classLibrary{public:structTransaction{Patronp;Transaction(Patronpp):p(pp){}Transaction();};};对于Transaction的默认构造函数,我有一个函数default_transaction()返回对静态对象的const引用,正如Stroustrup在“编程-原则和实践”中所推荐的使用C++”(第324页);推理:避免在构造函数代码

c++ - 不接受静态成员函数作为 constexpr 参数

以下代码被clang接受并被gcc拒绝。我想知道这是一个错误还是我遗漏了什么:#includetemplatestaticconstexprTApply(Tin,Tfun(T)){returnfun(in);}templatestructTriangle{usingAr=std::array;staticconstexprArfoo(Arline){returnline;}staticconstexprArresults=Apply({{1}},foo);//foo({1});isok};templateconstexprstd::arrayTriangle::results;intm

C++成员初始化、复制初始化和默认初始化

摘自TheC++ProgrammingLanguage,第4版,“17.3.1没有构造函数的初始化”部分,第489页书中示例中标记的行无法编译并出现此错误-$g++-std=c++11ch17_pg489.cppch17_pg489.cpp:Infunction'intmain()':ch17_pg489.cpp:32:34:error:couldnotconvert's9'from'Work'to'std::string{akastd::basic_string}'Workcurrently_playing{s9};//copyinitialization我有Cygwin$g++--

c++ - 为什么未初始化的 const 成员在 C 中的处理方式与在 C++ 中的处理方式不同?

这个问题在这里已经有了答案:constinCvsconstinC++(5个答案)关闭7年前。我为要链接的库包含一个Cheader。header有一个结构foo,我想在其中声明一个新变量bar。我收到编译器错误:error:uninitializedconstmemberin"structfoo"这些成员需要初始化是有道理的,因为以后不能为它们赋值。但是使用这个库的C程序可以做完全相同的事情并且它可以工作。C和C++标准有区别吗?这只是一个示例。实际上,我指的是libmtd.h(mtd-utils)中的结构mtd_dev_info。http://mtd-utils.sourcearchi

java - 返回对成员变量的引用时的 SWIG-Java 内存管理

我正在使用SWIG从Java访问C++代码。C++中的getter通常返回const引用:classB{public:constA&getA()const{returna_;}private:Aa_;};生成SWIG包装器。Java中的B::getA按预期返回引用。然而JVM并不知道这个引用与classB相关联。这可能会导致引用损坏:publicAcreateA(){Bb=newB();returnb.getA();}一旦垃圾收集器销毁Bb并且JVM对此一无所知,从createA返回的对象将无效。SWIG提供了解决此问题的文档:referencesandswig.然而,这意味着我需要手

c++ - "Define"类构造函数中的成员函数

大家好,我想知道您是否能够在类的构造函数中定义或实例化一个函数。假设您有这个简单的类:classcTest{public:cTest(boolbla);~cTest(){}voidsomeFunc(){}};cTest::cTest(boolbla){if(bla){someFunc=functionBody1;//orsomeFunc{functionBody1};//orsomethingdifferent}elsesomeFunc=functionBody2;}如果someFunc是一个经常被调用的函数,您可以避免每次调用该函数时都测试“bla”是否为真。我想了想,想到了两种可能

c++ - 当使用位域 union 替换位掩码时,访问非事件成员,好还是未定义?

来自thisquestion我了解到匿名结构和union已成为C11标准的一部分(来自评论)。然后我想用bitfieldunion来代替bitmask可能是个好主意,我发现其他人已经发布了一个问题并显示了anexample。,这和我的想法完全一样。该问题的答案同意使用位域union方法替换位掩码的安全性。但是,thepostthere的答案,据我了解,否认访问不活跃的union成员的安全性,说访问不活跃的union成员是未定义的行为。我认为这两个问题的答案是矛盾的:仅使用theexamplethere,在修改.user后,.raw的值会变成undefined(通过对thepost的回答

C++ 'substitute' 用于具有灵活数组成员的结构

考虑以下C99结构,以灵活的数组成员结尾:structhdr{size_tlen;size_tfree;charbuf[];};例如,len可以通过这样的内联函数(将被放入头文件)访问,将buf作为其参数:staticinlinesize_tslen(constchar*s){structhdr*h=(structhdr*)(s-(int)offsetof(structhdr,buf));returnh->len;}这是库的一部分,用C编译器编译。但是,我想从C++访问这个库;这实质上意味着相应的头文件(具有适当的extern"C"{...}保护)必须是有效的C++代码。一种可能的解决

c++ - GCC 向依赖默认构造函数的模板化类中的静态数据成员给出 "undefined reference"错误

我遇到了类似的问题:"undefinedreference"tostaticfieldtemplatespecialization但他们使用的解决方法对我不起作用。我有一个带有静态数据成员的CRTP类,其中之一是std::mutex。不幸的是,GCC(4.8.2)的链接器给我这个互斥锁的“undefinedreference”错误。Clang(3.4)没有。有解决方法吗?最初的问题(上面链接)在静态数据成员上调用了复制构造函数,迫使GCC发出一个符号,但是由于我的数据成员是std::mutex,所以这不是一个选项——复制构造函数被删除,并且有没有参数构造函数。我只是被冲洗了吗?我认为问

c++ - 调用构造函数之前是否初始化了静态成员?

我有一个带有std::map静态成员的类。我在执行构造函数体之前在同一个翻译单元(同一个cpp文件)中初始化它。我的程序没有输出就失败了。我发现了称为静态初始化顺序失败的问题,但我认为情况并非如此。classTest{public:staticstd::mapa;Test(std::stringID){/*inmycompletecode(whereconstructor*implementationandmapinitialization*areinaseparateTest.cppfile),thisfails,maybe*becausethemapisnotinitialized