关于静态成员变量在派生类中重新声明

本文通过一个具体的C++代码示例介绍了当基类和派生类中声明同名静态成员变量时,这些静态成员变量在内存中的布局方式。演示了如何通过指针偏移来访问这些静态成员变量,并提供了详细的输出结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

引用自https://blog.youkuaiyun.com/digu/article/details/1837559 修改

基类和派生类都声明了同名静态成员,它们的地址是连续的,如下代码,可以通过指针偏移互相访问;

#include<iostream>
class base
{
    int mx;
public:
    static int xxx[];
    static void fun(int x)
    {
        xxx[0]=x;
    }
    base(int x):mx(x){}
    friend std::ostream& operator<<(std::ostream& ,base&);
};
int base::xxx[]={1,2,3};


class test:public base
{
    public:
    test(int x):base(x){}


    static int xxx[];
    static void fun(int x)
    {
        xxx[0]=x;
    }


};
int test::xxx[]={4,5};


std::ostream& operator<<(std::ostream& os,base& s)
{
    os<<s.mx;
    return os;
}
int main()
{
    test x(321);
    base y(123);


    std::cout<<&base::xxx[0]<<std::endl;
    std::cout<<&test::xxx[0]<<std::endl;    
    
    std::cout<<base::xxx[0]<<std::endl;
    std::cout<<base::xxx[1]<<std::endl;
    std::cout<<base::xxx[2]<<std::endl;
    std::cout<<base::xxx[3]<<std::endl;
    std::cout<<base::xxx[4]<<std::endl;


    std::cout<<test::xxx[-3]<<std::endl;
    std::cout<<test::xxx[-2]<<std::endl;
    std::cout<<test::xxx[-1]<<std::endl;
    std::cout<<test::xxx[0]<<std::endl;
    std::cout<<test::xxx[1]<<std::endl;
    
    return 0;

}

输出结果:


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值