C++程序设计方法3:强制类型转换

强制类型转换(显示转换)

dynamic_cast<Dst_Type>(Src_var)

Src_var必须是引用或者指针类型,Dst_Type类中含有虚函数,否则会有编译错误;

若目标类与源类之间没有继承关系,则转化失败,返回空指针(注:失败并不是运行崩溃)

static_cast<Dst_Type>(Src_var)

基类对象不能转换为派生类对象,但基类指针可以转换为派生类的指针

派生类对象(指针)可以转化为基类的对象(指针)

没有继承关系的类之间,必须具有转换途径才能进行转换(要么自定义,要么是语言语法支持)

#include <iostream>
using namespace std;

class B
{
public:
    virtual void f() {}
};

class D :public B {};
class E {};

int main()
{
    D d1;
    B b1;
    //d1 = static_cast<D> (b1);//error:从基类无法转换回派生类
    b1 = static_cast<B>(d1);
    //b1 = dynamic_cast<B>(d1);//error:被转化的必须是指针或者引用
    B* pb1 = new B();
    D* pd1 = static_cast<D*>(pb1);
    if (pd1)
        cout << "ok" << endl;//基类指针可以转换为派生类的指针
    pd1 = dynamic_cast<D*>(pb1);
    if (pd1)
        cout << "ok" << endl;//基类不可以动态转化为派生类

    D* pd2 = new D();
    B* pb2 = static_cast<B*>(pd2);
    if (pb2)
        cout << "ok" << endl;//ok
    pb2 = dynamic_cast<B*>(pd2);
    if (pb2)
        cout << "ok" << endl;//ok

    E* pe = dynamic_cast<E*>(pb1);
    if (!pe)
        cout << "ok" << endl;//ok

    //pe = static_cast<E*>(pb1);//error:没有继承关系不能转换
    // E e = static_cast<E>(b1);//error:没有提供转换的途径
    return 0;
}
时间: 2024-07-30 13:37:13

C++程序设计方法3:强制类型转换的相关文章

js类型转换-字符串转整型、浮点型方法、强制类型转换等

1. 转换函数: js 提供了parseInt()和parseFloat()两个转换函数.前者把值转换成整数,后者把值转换成浮点数.只有对String类型调用这些方法, 这两个函数才能正确运行:对其他类型返回的都是NaN(Not a Number).这两个转换函数的结果都是将String数据类型转化为Number. 在 判断字符串是否是数字值前,parseInt()和parseFloat()都会仔细分析该字符串.parseInt()方法首先查看位置0处的 字符,判断它是否是个有效数字:如果不是,

C++的几种强制类型转换

有时我们希望显式地将对象强制类型转换成另外一种类型.例如,如果想在下面的代码中执行浮点数除法: int i, j; double slope = i / j; 就要使用某种方法将i和/或j显式地转换成double,这种方法称作强制类型转换. 命名的强制类型转换 一个命名的强制类型转换具有如下形式: cast_name<type>(expression); 其中,type是转换的目标类型而expression是要转换的值.如果type是引用类型,则结果是左值,cast-name是static_c

java中强制类型转换时,高位数截取成低位数的方法

/** * 强制类型转换中的补码.反码.原码一搞清楚 */ int b=233;//正整数强转 System.out.println((byte)b); //负数:原码的绝对值取反再加一 符号为不变 //00000000 00000000 00000000 11101001 // 1110 1001 补码 // 1110 1000 反码 // 1001 0111 原码 1+2+4+16 =-23 b=-233;//负整数强转 //10000000 00000000 00000000 111010

Js中的假值_ES5中定义的ToBoolean方法强制类型转换后值为false

你不知道的Javascript(中)--ToBoolean javascript中的值可以分为以下两类: 1.可以被强制类型转换为false的值 2.其他(被强制类型转换为true的值) 假值---以下是js的ES规范中定义了的假值: undefined null false +0.-0和NaN ""-空字符串 假值的不二强制类型转换结果为false.一般除假值以外的都是真值. 假值对象--封装了假值的对象 eg: var a=new Boolean(false); var b=new

C++中static_cast和dynamic_cast强制类型转换

在C++标准中,提供了关于类型层次转换中的两个关键字static_cast和dynamic_cast. 一.static_cast关键字(编译时类型检查) 用法:static_cast < type-id > ( expression ),该运算符把expression转换为type-id类型,但没有运行时类型检查来保证转换的安全性,它主要有如下几种用法: (1)用于基本数据类型之间的转换,如把int转换为char,把int转换成enum,但这种转换的安全性需要开发者自己保证(这可以理解为保证

C++中的向上类型转换和向下类型转换+四种强制类型转换

转自博客:http://blog.csdn.net/wangweitingaabbcc/article/details/7720979# 在c++的世界中有这样两个概念,向上类型转换,向下类型转换,分别描述的是子类向基类,和基类向子类的强制类型转换. 向上强制类型转换 切割:覆盖方法和子类数据丢失的现象生成切割(slice) class Base { public: int b; virtual void Test() { cout << "base" <<en

C++强制类型转换:static_cast、dynamic_cast、const_cast、reinterpret_cast

1. c强制转换与c++强制转换 c语言强制类型转换主要用于基础的数据类型间的转换,语法为: (type-id)expression//转换格式1 type-id(expression)//转换格式2 c++除了能使用c语言的强制类型转换外,还新增了四种强制类型转换:static_cast.dynamic_cast.const_cast.reinterpret_cast,主要运用于继承关系类间的强制转化,语法为: static_cast<new_type> (expression) dynam

C++中4种强制类型转换

不过为了完成强制类型转换,C++中已经为我们提供了4中标准方法,它们是dynamic_cats, static_cast, const_cast, reinterpret_cast,用法形式为:dynamic_cast<类型说明符>(表达式),之所以分成4类,就表示他们各自有着不同的使用环境,下面转载的文章会有详细的说明. const_cast,字面上理解就是去const属性.static_cast,命名上理解是静态类型转换.如int转换成char.dynamic_cast,命名上理解是动态类

int类型和byte类型的强制类型转换

今天在读<Java网络编程>这本书的第二章 流 时,看到书中有一个地方关于int强制转换为byte类型时应注意的地方.这个地方有点细节,不过就应该把这种细节把握住. 情况是这样的,讲到InputStream的抽象方法read时,说到read返回一个int型,但实际是一个byte型的数据.这点从API也能考证.如图: 那么问题来了,int占4个字节,byte占1个字节,我们循环读取的时候将int型数组强制类型转换成byte时,会发生什么情况呢?代码如下: 1个字节占8位,既然实际返回的是byte