草庐IT

static-members

全部标签

【C++】类与对象—— 初始化列表 、static 静态成员、

类与对象1再谈构造函数1.1构造函数体赋值1.2初始化列表语法:建议:初始化顺序:注意:1.3explicit关键字2static静态成员2.1概念2.2声明成员变量2.3使用类的静态成员2.4定义静态成员总结Thanks♪(・ω・)ノ谢谢阅读!!!下一篇文章见!!!1再谈构造函数1.1构造函数体赋值在创建对象时,编译器通过调用构造函数,给对象中各个成员变量一个合适的初始值,以我们之前实现的Date类对象为例。classDate{public: Date(intyear,intmonth,intday) { _year=year; _month=month; _day=day; }pri

c++ - 为什么我们不能有非常量类级别的静态变量?

为什么theVisualC++compilerrefusetocompilethiscode?我明明知道错误是:ErrorC2864:Singleton::p:Onlystaticconstintegraldatamemberscanbeinitializedwithinaclass但是为什么?(即是否存在不允许这样做的技术原因?)这是特定于编译器的行为还是标准强制要求的?在全局范围内似乎没问题,为什么在类范围内不行呢?看起来也像notallcompilersmindthis.此外,解决此问题的正确方法是什么?templatestructSingleton{staticT*p=0;//

c++ - C/C++ : passing a struct/class with a member array to a function by value

structA{intV[100];};voidf(Aa){a.V[0]=30;}intmain(){Aa;a.V[0]=10;f(a);cout我期望30作为输出,但我得到了10。我知道,如果参数是按值传递的,数组(也是类/结构的成员)也是按引用传递的。相反,当成员时,它们似乎是通过拷贝传递的。是真的吗? 最佳答案 按值将数组作为参数传递给函数会导致它衰减为指向第一个元素的指针,这就像按引用传递一样。将一个包含数组(不是指针)的对象按值传递给函数会导致该对象(包括数组)被复制到函数的参数中。如果您想在调用站点看到该修改,请通过非常

C++ : How to ensure that a class member variable is modifiable only within a certain method

我在MacOSSierra上使用带有clang的C++14。我想通过设计来执行规则。以下是规则。我的类中有一个成员变量说:unsignedintm_important_num;我的类中有4个方法。fun1();fun2();fun3();fun4();目标:我只希望fun2()能够更改m_important_num的值。问题:如果fun2()以外的任何方法更改变量,是否有可能使其成为编译器错误?一种可能的方法是将其声明为const以某种方式授权fun2()更改const变量?这是一个好的解决方案吗?或者他们有更好的解决方案吗?次要问题:尝试做这样的事情是错误的设计吗?

c++ - C++ 中的信号 : using a member function

我在使用signal()时遇到了这个问题:这段代码编译得很好:#include#include#includevoidterminate(intparam){printf("Terminatingprogram...\n");exit(1);}intmain(){signal(SIGTERM,terminate);return0;}但是,下面的代码会抛出这个错误:g++-Wall-c-ggoober.cppgoober.cpp:Inmemberfunction`voidGOOBER::yarrgh()':goober.cpp:5:error:argumentoftype`void(GO

c++ - RAII : Initializing data member in const method

在RAII中,资源在被访问之前不会被初始化。但是,许多访问方法都声明为常量。我需要调用一个mutable(非常量)函数来初始化一个数据成员。示例:从数据库加载structMyClass{intget_value(void)const;private:voidload_from_database(void);//Loadsthedatamemberfromdatabase.intm_value;};intMyClass::get_value(void)const{staticboolvalue_initialized(false);if(!value_initialized){//The

c++ - 模板类 : static members not inherited

这个问题在这里已经有了答案:Whydoesn'taderivedtemplateclasshaveaccesstoabasetemplateclass'identifiers?(4个答案)关闭7年前。下面的代码templatestructBase{staticconstinta=c+5;};templatestructDerived:Base{staticconstintb=a+5;};...编译失败因为awasnotdeclaredinthisscope.明确指定Base::a有效,但从逻辑上讲这不是必需的,因为我们是从Base派生的.这是预期的行为(以及为什么)还是我遗漏了什么?

C++ 多态性 : Is there any way to find the address of an object's member function?

如果我有一个纯虚拟基类及其多个派生...classBase{public:virtualvoidmethod1()=0;}classDerived1:publicBase{public:voidmethod1()override{...}}classDerived2:publicBase{public:voidmethod1()override{...}}有什么方法可以让持有未知派生类型对象的Base*的代码确定它持有的对象的method1()函数的地址Base*指针指向?我想做的是这样的:voidsomeOtherFunction(Base*pb){printf("IfIcallpb

c++ - 我可以在抽象类中有静态数据成员吗?

我设计了一系列相关的类,为了能够管理它们,我让它们派生自一个抽象类。这些类都需要访问一系列共享资源,我发现自己在每个类中创建了一个指针vector,所有这些都相同(它们必须相同)。似乎在基类中创建一个静态成员会让所有派生类都可以访问这个vector,这意味着我只需要构建它一次(它在构建之后也不会改变,只是查找)。我的问题是这是否可以,如果可以,我该如何构建它,而不从其中一个派生类调用“填充vector”方法?我的想法是做类似的事情classResource{};enumR{RES0,RES1};classAbstractClass{public:virtualvoidOnInit()=

c++ - Ptr-to-member 模板参数的 Friend 语法

好吧,所以我认为这是一个纯粹的C++语法问题。我有一个用ptr-to-member作为其模板参数之一定义的类:templateclassMy_list{我有另一个简单的类,它是这个类的友元。通常,我会写:classMy_friend_class{templatefriendclassMy_list;};...但是,因为第二个模板参数不是那么自由...我该如何表达友元?谢谢! 最佳答案 也许更好的问题是“为什么?”而不是“如何?”您到底想达到什么目的?当您的C++代码变得复杂和丑陋时,这通常是一个警告,表明您正在错误地处理问题。