dynamic_cast和static_cast的区别

1、子类转换到父类自动转换,不需要强制转型

// Derived派生类(子类)

// Base 基类(父类)

Base *A =new Derived; //Derived->Base.

2、父类转换子类需要强制类型转换

就要使用dynamic_cast和static_cast转换

dynamic_cast和static_cast区别

例子:

class Base{}//基类

class Derived:public Base{}  //单继承(子类1)

class Base1{}//基类

class Derived1:publicBase,public Base1{}  //多重继承(子类2)

 

Base*pD=newDerived;

Derived*pD1=dynamic_cast<Derived*>(pD);//基类指针pD指向派生类的指针且当前派生类为单继承可以用dynamic_cast或者static_cast

Derived1*pD1=dynamic_cast<Derived1*>(pD);//基类指针pD指向派生类的指针且当前派生类为多重继承,只能用dynamic_cast

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当然!我可以为您提供一些示例代码来说明 `dynamic_cast` 和 `static_cast` 的用法。 首先,让我们看一下 `dynamic_cast`。它用于在运行时进行类型转换,并且通常用于多态类型的向下转换。假设我们有一个基类 `Animal` 和两个派生类 `Cat` 和 `Dog`: ```cpp #include <iostream> class Animal { public: virtual void makeSound() { std::cout << "Animal makes a sound." << std::endl; } }; class Cat : public Animal { public: void makeSound() override { std::cout << "Cat meows." << std::endl; } }; class Dog : public Animal { public: void makeSound() override { std::cout << "Dog barks." << std::endl; } }; int main() { Animal* animal = new Cat(); // 使用 dynamic_cast 将基类指针转换为派生类指针 Cat* cat = dynamic_cast<Cat*>(animal); if (cat) { // 转换成功,调用 Cat 类的方法 cat->makeSound(); } else { // 转换失败,animal 并不指向 Cat 类型的对象 std::cout << "Failed to cast to Cat." << std::endl; } delete animal; return 0; } ``` 在上面的代码中,我们创建了一个基类指针 `animal` 并将其指向一个派生类对象 `Cat`。然后,我们使用 `dynamic_cast` 将基类指针转换为派生类指针 `cat`。如果转换成功,我们将调用 `Cat` 类的方法 `makeSound()`。否则,我们将输出一条转换失败的消息。 接下来,让我们看一下 `static_cast`。它用于进行静态类型转换,并且可以在不同类型之间进行转换(如整数和指针之间的转换)。下面是一个简单的示例: ```cpp #include <iostream> int main() { int num1 = 10; double num2 = static_cast<double>(num1); std::cout << "num1: " << num1 << std::endl; std::cout << "num2: " << num2 << std::endl; return 0; } ``` 在上面的代码中,我们使用 `static_cast` 将整数 `num1` 转换为双精度浮点数 `num2`。然后,我们输出这两个变量的值。 这就是关于 `dynamic_cast` 和 `static_cast` 的简单示例代码。请记住,这只是基本用法的示例,并且在实际开发中可能会有更复杂的用法和注意事项。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值