当前位置: 代码迷 >> 综合 >> static_cast 用法
  详细解决方案

static_cast 用法

热度:80   发布时间:2023-11-17 03:55:58.0

原文地址:http://blog.csdn.net/jofranks/article/details/7828331


用法:static_cast < type-id > ( expression )

 

《C++primer 第四版》中说编译器隐式执行的任何类型转换都可以由static_cast显式完成!

要注意的是,此转换没有运行时检测安全!他不能转换掉expression的const、volatile、或者__unaligned属性。他也不是用来去掉static属性的! 大家应该清楚static限定符吧,他会造成范围性的影响,而const则不同,他只是限定变量或对象自身!

当你用static限定符限定一个变量的时候,就拿类中吧,他会随类的第一个实例对象的出现而出现,并且可以被这个类的所有对象所使用!!

C++中的static_cast执行非多态的转换,用于代替C中通常的转换操作。

对于我们的static_cast转换符,他不仅可以应用到指针和引用上,而且还可以应用到基础数据结构和对象上!如:

[cpp] view plaincopy
  1. double da = 1.1;  
  2. void *pa = &da;  
  3. double *dp = static_cast<double*>(pa);  
  4.   
  5. int ia = static_cast<int>(da);  
  6.   
  7. cout << *dp << endl;  
  8. cout << ia << endl;  

OK,代码编译通过!

《C++primer》告诉我们,对于一个由较大的算术类型到一个较小的类型的赋值,编译器通常会报错,然后当我们显示地提供强制类型转换的时候,警告信息就关闭了!

要知道我们的static_cast的真正用处不是在指针的引用上,而是在基础类型的转换和对象的转换上!


我们的static_cast也支持指向基类的指针和指向子类的指针之间的转换!

如:

[cpp] view plaincopy
  1. class A  
  2. {  
  3. public:  
  4.     virtual void  a()  
  5.     {  
  6.         cout << 'a' << endl;  
  7.     }  
  8.   
  9.     virtual void b()  
  10.     {  
  11.         cout << 'a' << endl;  
  12.     }  
  13.   
  14. private:  
  15.     int i;  
  16. };  
  17.   
  18. class B:public A  
  19. {  
  20. public:  
  21.     virtual void a()  
  22.     {  
  23.         cout << 'b' << endl;  
  24.     }  
  25. };  
  26.   
  27. int main(void)  
  28. {  
  29.     A *pa = new A();  
  30.     B *pb = static_cast<B*>(pa);  
  31.   
  32.   
  33.     B *ppb = new B();  
  34.     A *ppa = static_cast<A*>(ppb);  
  35.   
  36.     return 0;  
  37. }  

OK,编译通过!

但是在这里要注意的是,我们从基类转换到子类是一个不安全的行为,在这里先做了解,在下面的dynamic_cast中还会讲到这方面的问题!