标准C++中的强制类型转换符

  1. const_castreinterpret_caststatic_castdynamic_cast等等。  
  2.   
  3.   
  4.   
  5.   
  6. 1)static_cast<T*>(a)  
  7.   
  8. 将地址a转换成类型T,T和a必须是指针、引用、算术类型或枚举类型。  
  9.   
  10. 表达式static_cast<T*>(a), a的值转换为模板中指定的类型T。在运行时转换过程中,不进行类型检查来确保转换的安全性。  
  11.   
  12.   
  13.   
  14.   
  15. 例子:  
  16.   
  17.   
  18.   
  19.   
  20. class B { ... };  
  21.   
  22. class D : public B { ... };  
  23.   
  24. void f(B* pb, D* pd)  
  25.   
  26. {  
  27.   
  28.    D* pd2 = static_cast<D*>(pb);        // 不安全, pb可能只是B的指针  
  29.   
  30.   
  31.   
  32.   
  33.    B* pb2 = static_cast<B*>(pd);        // 安全的  
  34.   
  35.    ...  
  36.   
  37. }  
  38.   
  39.   
  40.   
  41.   
  42.   
  43.   
  44.   
  45. class B { ... };  
  46.   
  47. class D : public B { ... };  
  48.   
  49. void f(B* pb, D* pd)  
  50.   
  51. {  
  52.   
  53.    D* pd2 = static_cast<D*>(pb);        // 不安全, pb可能只是B的指针  
  54.   
  55.   
  56.   
  57.   
  58.    B* pb2 = static_cast<B*>(pd);        // 安全的  
  59.   
  60.    ...  
  61.   
  62. }  
  63.   
  64.   
  65.   
  66.   
  67.   
  68.   
  69.   
  70. class B { ... };  
  71.   
  72. class D : public B { ... };  
  73.   
  74. void f(B* pb, D* pd)  
  75.   
  76. {  
  77.   
  78.    D* pd2 = static_cast<D*>(pb);        // 不安全, pb可能只是B的指针  
  79.   
  80.   
  81.   
  82.   
  83.    B* pb2 = static_cast<B*>(pd);        // 安全的  
  84.   
  85.    ...  
  86.   
  87. }  
  88.   
  89.   
  90.   
  91.   
  92. 2)dynamic_cast<T*>(a)  
  93.   
  94. 完成类层次结构中的提升。T必须是一个指针、引用或无类型的指针。a必须是决定一个指针或引用的表达式。  
  95.   
  96. 表达式dynamic_cast<T*>(a) 将a值转换为类型为T的对象指针。如果类型T不是a的某个基类型,该操作将返回一个空指针。  
  97.   
  98.   
  99.   
  100.   
  101. 例子:  
  102.   
  103. class A { ... };  
  104.   
  105. class B { ... };  
  106.   
  107. void f()  
  108.   
  109. {  
  110.   
  111.   A* pa = new A;  
  112.   
  113.   B* pb = new B;  
  114.   
  115.   void* pv = dynamic_cast<A*>(pa);  
  116.   
  117.   // pv 现在指向了一个类型为A的对象  
  118.   
  119.   ...  
  120.   
  121.   pv = dynamic_cast<B*>(pb);  
  122.   
  123.   // pv 现在指向了一个类型为B的对象  
  124.   
  125. }  
  126.   
  127.   
  128.   
  129.   
  130. 3)const_cast<T*>(a)  
  131.   
  132. 去掉类型中的常量,除了const或不稳定的变址数,T和a必须是相同的类型。  
  133.   
  134. 表达式const_cast<T*>(a)被用于从一个类中去除以下这些属性:constvolatile, 和 __unaligned。  
  135.   
  136.   
  137.   
  138.   
  139. 例子:  
  140.   
  141.   
  142.   
  143.   
  144.   
  145.   
  146.   
  147. class A { ... };  
  148.   
  149. void f()  
  150.   
  151. {  
  152.   
  153.  const A *pa = new A;//const对象  
  154.   
  155.  A *pb;//非const对象  
  156.   
  157.   
  158.   
  159.   
  160. //pb = pa; // 这里将出错,不能将const对象指针赋值给非const对象  
  161.   
  162.  pb = const_cast<A*>(pa); // 现在OK了  
  163.   
  164. ...  
  165.   
  166. }  
  167.   
  168.   
  169.   
  170.   
  171.   
  172.   
  173.   
  174. class A { ... };  
  175.   
  176. void f()  
  177.   
  178. {  
  179.   
  180.  const A *pa = new A;//const对象  
  181.   
  182.  A *pb;//非const对象  
  183.   
  184.   
  185.   
  186.   
  187. //pb = pa; // 这里将出错,不能将const对象指针赋值给非const对象  
  188.   
  189.  pb = const_cast<A*>(pa); // 现在OK了  
  190.   
  191. ...  
  192.   
  193. }  
  194.   
  195.   
  196.   
  197.   
  198.   
  199.   
  200.   
  201. class A { ... };  
  202.   
  203. void f()  
  204.   
  205. {  
  206.   
  207.  const A *pa = new A;//const对象  
  208.   
  209.  A *pb;//非const对象  
  210.   
  211.   
  212.   
  213.   
  214. //pb = pa; // 这里将出错,不能将const对象指针赋值给非const对象  
  215.   
  216.  pb = const_cast<A*>(pa); // 现在OK了  
  217.   
  218. ...  
  219.   
  220. }  
  221.   
  222.   
  223.   
  224.   
  225. 4)reinterpret_cast<T*>(a)  
  226.   
  227. 任何指针都可以转换成其它类型的指针,T必须是一个指针、引用、算术类型、指向函数的指针或指向一个类成员的指针。  
  228.   
  229. 表达式reinterpret_cast<T*>(a)能够用于诸如char* 到 int*,或者One_class* 到 Unrelated_class*等类似这样的转换,因此可能是不安全的。  
  230.   
  231.   
  232.   
  233.   
  234. 例子:  
  235.   
  236. class A { ... };  
  237.   
  238. class B { ... };  
  239.   
  240. void f()  
  241.   
  242. {  
  243.   
  244.   A* pa = new A;  
  245.   
  246.   void* pv = reinterpret_cast<A*>(pa);  
  247.   
  248.   // pv 现在指向了一个类型为B的对象,这可能是不安全的  
  249.   
  250.   ...  
  251.   
  252. }
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值