[QQ群: 189191838,对算法和C++感兴趣可以进来]

      开篇立意

C++中各种转换令人眼花缭乱,看似差不多,实际差很多,而且在当今时间,做一个"差不多先生"其实挺难的,一不小心可能就被社会淘汰了。

数据转换(当然也包括各种对象类型的转换)是我们经常用到的,比如说一个Int转换成一个double之类的等等。如果说一个人什么样的场合穿什么样的衣服,说什么样的话是一件非常重要的事情。那么,对于什么样的数据对象用什么样的转换方式也是very important!本篇将对标题上的四种转换方式一一描述。

reinterpret_cast  直接转换

       这是所有转换里面最简单粗暴的方式了,和一个男生喜欢一个女生,然后直接按倒在地差不多性质。有时候效果很好,速度很快,但是危险很高,指不定就是一个强奸罪,所以用的很少。

  1. int *m;
  2. char *ch=(char*)m;
  3. char ch1=reinterpret_cast<char> (m);//和上面的效果是一样的,不进行检查,直接转换

看了上面的代码,想必大家知道了它的作用了。在实际中,除非确定可以转换成功,否则尽量别用。

static_cast

      编译器中的所有隐式转换都可以用static_cast来显示的完成,一般来说只有可隐式转换时,static_cast之间的转换才是合法的。我这里说的是一般,那就还有特殊,特殊就是继承类和父类层次转换,具体稍后再说。

那么既然可以隐式转换为什么需要显示的用static_cast转换呢?当然,程序的易读性是一个考虑的因素,还有几个其他因素如下:

void指针转换成其他类型指针,这种情况不用显示转换不行吧;还有改变通常的标准转换,比如int 转换成char,或者char改成int;当然还有用于类层次结构中基类和子类之间指针或引用的转换()。进行上行转换(把子类的指针或引用转换成基类表示);进行下行转换(把基类指针或引用转换成子类指针或引用)。

  1. class base{
  2. public:
  3. void print(){
  4. cout<<"base"<<endl;
  5. }
  6. };
  7. class child:public base{
  8. public:
  9. void print(){
  10. cout<<"child"<<endl;
  11. }
  12. };
  1. 1 base *b=new base();
  2. child *c=new child();
  3. b=static_cast<child*>(c);//上行转换,子类指针转换成父类
  4. b->print();
  1. base *b=new base();
  2. child *c=new child();
  3. c=static_cast<child*>(b);//下行转换,父类指针转换成子类
  4. b->print();

这里特别注意,由于下行转换没有动态类型检查,所以是不安全的。而dynamic_cast会进行检查。

   dynamic_cast

dynamic_cast转换的对象必须是类的指针或者引用,和void*;

dynamic_cast是运行时是会进行类型检查的。并且这个信息存储在类的虚函数表中,只有存在虚函数的类才会虚函数表,对没有虚函数的类进行转换会导致编译错误。

还是上面那个例子:如果改成下面,在下行转换的时候因为父类没有定义虚函数,所以会编译错误。

  1. base *b=new base();
  2. child *c=new child();
  3. c=dynamic_cast<child*>(b);//下行转换,父类指针转换成子类
  4. b->print();

当然,在上行转换的时候效果和static_cast<>;是一样的。

所以dynamic_cast一般是在多态中上下行转换比较多见。如果转换到指针类型失败了,dynamic_cast的结果是0;如果是引用的时候失败了,它则会抛出一个bad_cast类型的异常。

const_cast

顾名思义,它似乎应该用于和const相关。也的确如此,他就是remove或者add表达式的const性质。

  1. int x=;
  2. const int *y=const_cast<int*>(&x);

下面是remove它的const性质

  1. const int x=;
  2. int *y=const_cast<int*>(&x);

本文把四种显示转换的用法基本都有所涉猎,希望对大家有所帮助。错误处请指正!不甚感谢!

参考文献:http://stackoverflow.com/questions/28002/regular-cast-vs-static-cast-vs-dynamic-cast

http://stackoverflow.com/questions/332030/when-should-static-cast-dynamic-cast-const-cast-and-reinterpret-cast-be-used

http://blog.csdn.net/bzhxuexi/article/details/17021559

转载请注明出处:http://www.cnblogs.com/xiaoyi115/p/3629696.html

你也许还不知道const_cast,static_cast,dynamic_cast,reinterpret_cast的区别吧?的更多相关文章

  1. c++ 数据类型转换: static_cast dynamic_cast reinterpret_cast const_cast

    c++ 数据类型转换: static_cast dynamic_cast reinterpret_cast const_cast  [版权声明]转载请注明出处 http://www.cnblogs.c ...

  2. C++雾中风景11:厘清C++类型转换(static_cast,dynamic_cast,reinterpret_cast,const_cast)

    C++是一门弱类型的语言,提供了许多复杂和灵巧类型转换的方式.笔者之前写的Python与Go都是强类型的语言,对这种弱类型的设计实在是接受无力啊~~ ( 生活所迫,工作还得写C++啊~~)C++语言提 ...

  3. static_cast, dynamic_cast, reinterpret_cast, const_cast区别比较

    隐式转换(implicit conversion) ; int b; b=a; short是两字节,int是四字节,由short型转成int型是宽化转换(bit位数增多),编译器没有warning,如 ...

  4. C++ static_cast dynamic_cast reinterpret_cast const_cast转换

    static_cast <type-id> ( expression ) 和C风格的类型转换相似,可以转换一个指针到基类,或者派生类.不做Run-time类型检查,这样转换并不总是安全的. ...

  5. static_cast, dynamic_cast, reinterpret_cast, const_cast的区别

    static_cast最像C风格的强制转换,很多时候都需要程序员自身去判断转换是否安全.但是相对C风格的强制转换,在无关类的类指针之间转换上,有安全性的提升. dynamic_cast是运行时的转换吧 ...

  6. Qt 中C++ static_cast 和 reinterpret_cast的区别

    1.C++中的static_cast执行非多态的转换,用于代替C中通常的转换操作.因此,被做为隐式类型转换使用.比如: int i; float f = 166.7f; i = static_cast ...

  7. Qt 中C++ static_cast 和 reinterpret_cast的区别(static_cast是隐式类型转换,会有数据损失,reinterpret_cast是底层二进制转换,没有数据损失)

    1.C++中的static_cast执行非多态的转换,用于代替C中通常的转换操作.因此,被做为隐式类型转换使用.比如: int i; float f = 166.7f; i = static_cast ...

  8. static_cast ,reinterpret_cast

    用法:static_cast < type-id > ( expression ) 该运算符把expression转换为type-id类型,但没有运行时类型检查来保证转换的安全性.它主要有 ...

  9. static_cast和reinterpret_cast

    static_cast和reinterpret_cast 相同点:都是暴力转换,从一个类型转换为另一个类型,对于类指针不会保证安全性   static_cast和reinterpret_cast的区别 ...

随机推荐

  1. [译]9-spring bean的生命周期

    spring中bean的生命周期比较容易理解.bean在实例化之后有时需要调用某个初始化方法进行一些初始化的工作.同样的 ,当bean在销毁之前有时需要做一些资源回收的工作. 尽管bean在实例化和销 ...

  2. Leetcode 664.奇怪的打印机

    奇怪的打印机 有台奇怪的打印机有以下两个特殊要求: 打印机每次只能打印同一个字符序列. 每次可以在任意起始和结束位置打印新字符,并且会覆盖掉原来已有的字符. 给定一个只包含小写英文字母的字符串,你的任 ...

  3. ssl证书原理

    SSL证书(HTTPS)背后的加密算法 SSL证书(HTTPS)背后的加密算法 之前我们介绍SSL工作原理了解到当你在浏览器的地址栏上输入https开头的网址后,浏览器和服务器之间会在接下来的几百毫秒 ...

  4. Error “can't use subversion command line client : svn” Probably the path to Subversion executable is wrong

    错误提示如图. 大概意思就是SVN路径不对 解决方法如下: 首先下载Subversion 1.8.13(1.8) 下载链接(https://www.visualsvn.com/downloads/) ...

  5. 爬虫:Scrapy14 - Telnet 终端(Telnet Console)

    Scrapy 提供了内置的 Telnet 终端,以供检查,控制 Scrapy 运行的进程.Telnet 仅仅是一个运行在 Scrapy 进程中的普通 Python 终端.因此你可以在其中做任何是. T ...

  6. 用canvas实现鼠标拖动绘制矩形框

    需要用到jCanvas插件和jQuery. jCanvas下载:https://raw.githubusercontent.com/caleb531/jcanvas/master/jcanvas.mi ...

  7. HDU 5790 Prefix(字典树+主席树)

    Prefix Time Limit: 2000/4000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others) Total Sub ...

  8. 【BestCoder #48】

    与之前一样,秒刷A和B,然后就永远卡在了C B也因为少看一句话被Hunt掉了 说说C的做法吧(分块大法好 给定一个序列,每次询问区间l-r,求∑(ai^bi),其中bi是指ai在区间中的出现次数,ai ...

  9. 2016华中农业大学预赛 B 数学

    Problem B: Handing Out Candies Time Limit: 1 Sec  Memory Limit: 128 MBSubmit: 272  Solved: 20[Submit ...

  10. CSU 2136 ——湖南多校对抗赛 I

    2136: 统帅三军! Submit Page   Summary   Time Limit: 1 Sec     Memory Limit: 128 Mb     Submitted: 55     ...