类间偏移地址以及切割,static_cast

本文通过两个C++示例介绍了结构体成员变量的偏移计算方法及多态性的使用技巧。首先展示了如何计算结构体内特定成员相对于结构体起始位置的偏移量,并给出两种实现方式;随后,通过基类指针调用派生类方法的实例,解释了多态性的应用,包括dynamic_cast和static_cast的区别。

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

/*
//得到A的每一个变量的偏移地址offset,可以产生一个object,也可以不产生~
#include <iostream>
#include <functional>
using namespace std;
struct A{
    int i;
    int j;
};
int main(void){
    A a;
    cout << (unsigned long)(&(a.j)) - (unsigned long)(&(a)) << endl;//这种方式可以行得通
    cout << (unsigned long)(&((A*)0)->j) << endl; //这种方式感觉更好,这里需要理解 (A*)0的意思
}
*/

//第二个例子是切割,以及dynamic_cast的用法,以及强制转化 static_cast之间的用法
#include <iostream>
#include <functional>
using namespace std;
class A{
public:
    A(){

    }
    virtual void print(){
        cout << "A" << endl;
    }
};
class B :public A{
public:
    B(){
    }
    void print(){
        cout << "B" << endl;
    }
};
void printClass(A b){
    b.print();
}
int main(void){
    A *derived = dynamic_cast<B*>(new B());
    B s = (*static_cast<B*>(derived));
    A g = *derived;
    printClass(*derived);
    printClass(g);
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值