C++,Python中基类(父类)与派生类(子类)会共享基类的静态成员变量(类属性)

开始这个问题,我在Python中发现的。先说一下python中的吧。

Python中:

class A:
    count = 0
    def __init__(self):
        A.count += 1

class B(A):
    def __init__(self):
        A.__init__(self)

obj1 = A()
obj2 = A()
print('A.count:', A.count,'  B.count:', B.count)
obj3 = B()
obj4 = B()
print('A.count:', A.count,'  B.count:', B.count)

执行结果:

A类的构造方法中每创建一个对象count会加一。

程序中先创建基类A的对象,发现基类的类属性和派生类的类属性都count改变了。

然后创建派生类B的对象,发现基类与派生类的类属性也同时改变了。

所以,派生类和基类会共用基类的类属性。编程的时候应该注意。

也可以通过打印变量地址的方法来验证:

两个变量地址相同。

另外,直接通过派生类名来引用基类的类属性赋值,会被认为是派生类重新创建了一个类属性,而不是调用的基类属性。

C++中:

#include <iostream>
using namespace std;

class A
{
public:
    A()
    {
        count++;
    }
    static int count;
};
int A::count = 0;

class B : public A
{
};

int main(void)
{
    cout <<"A类静态成员变量:"<< A::count<<"  B类静态成员变量:"<<B::count<< endl;
    A obj1;
    A obj2;
    cout <<"A类静态成员变量:"<< A::count<<"  B类静态成员变量:"<<B::count<< endl;
    B obj3;
    B obj4;
    B obj5;
    cout <<"A类静态成员变量:"<< A::count<<"  B类静态成员变量:"<<B::count<< endl;
    system("pause");
}

执行结果:

程序中定义基类的对象,发现基类和派生类的静态数据成员同步发生了改变。

然后定义B类的对象,结果还是同步改变。

加上一行代码打印两个变量的地址。

cout <<"A count:"<<&(A::count)<<"   B count:"<<&(B::count)<<endl;

地址相同。

所以,在C++中基类和派生类也是共享基类的静态数据成员的。

如有不当之处,请指正。

 

派生类构造函数是在创建派生类对象时自动调用的,它的主要作用是对基类成员以及自身新增的成员进行初始化。当创建一个新的派生类对象时,会首先调用基类的构造函数(如果有默认或者显式指定的),然后调用自己的构造函数。 为了对基类子类成员初始化,你可以这样做: 1. **继承初始化**:如果你只是简单地想确保基类的所有成员都被初始化,可以在派生类的构造函数的第一部分调用基类的无参构造函数。例如,在C++中: ```cpp class Base { public: Base() : value(0) {} // 基类的初始化 int value; }; class Derived : public Base { public: Derived() : Derived(10) {} // 调用自己的带参数构造函数 Derived(int v) : Base(), derivedValue(v) { // 对自身成员初始化 this->value = v * 2; // 可能还需要额外处理 derivedValue = v + 1; } int derivedValue; }; ``` 2. **显式初始化**:如果你想对特定的基类子类成员提供更具体的初始值,可以直接在构造函数内设置它们。 ```cpp class Derived : public Base { public: Derived() : Base(5), derivedValue(15) {} // 显式初始化基类子类成员 private: int derivedValue; }; ``` 在这个例子中,`Derived`对象在创建时不仅设置了`Base`的`value`为5,还设置了自身的`derivedValue`为15。 **相关问题--:** 1. 构造函数链式调用是如何工作的? 2. 当派生类的构造函数需要进一步操作基类的成员时,应该如何设计? 3. 在Python中,的初始化顺序是什么样的?
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值