C语言中,存在强制类型转换的概念。在C++中,C的做法同样适用。但是,C++也有自己的类型转换的方式,就是使用reinterpret_cast<>。例如,
创新互联公司一直通过网站建设和网站营销帮助企业获得更多客户资源。 以"深度挖掘,量身打造,注重实效"的一站式服务,以网站制作、成都网站建设、移动互联产品、成都全网营销推广服务为核心业务。十年网站制作的经验,使用新网站建设技术,全新开发出的标准网站,不但价格便宜而且实用、灵活,特别适合中小公司网站制作。网站管理系统简单易用,维护方便,您可以完全操作网站资料,是中小公司快速网站建设的选择。
char* str = "chentong"; int* p = reinterpret_cast(str);
通过这种方式,就把指向char*类型的str,强制转换成了指向int*。
仅仅这样做,是不够的。因为,str指向的一个字符串,一个确定的字符串,也就是说,要求是不可改写,也就是可读不可写。所以,为了达到这一目的,我们将str指向的内容不可修改。操作如下:
const char* str = "chentong";
这样做后,确实,str所指向的内容不可修改了,但是,这样做,又带来一个问题,那就是,reinterpre_cast<>这种强制转换,不可以去掉类似与const这样的属性。所以,我们要通过一些手段,将str的const属性去掉。幸运的是,C++确实提供了解决方案。通过const_cast<>。代码如下:
const char* str = "chentong"; char* str2 = const_cast < char* > ( str );
这样一来,就去掉了str的const属性。
那么,完整的操作方式,
const char* str = "chentong"; char* str2 = const_cast < char* > ( str ); int* p = reinterpret_cast < char* > ( str2 );
这样就完成了类型的转换。
接下来讲一下动态类型转换。首先得清楚的是,动态类型转换,只能用于存在虚函数的类。假设我有三个类,
class Human { public: virtual void eating( void ) { cout << "use hand to eat" << endl; } }; class Englishman : public Human { public: //覆写 void eating(void) { cout << "use knife to eat" << endl; } }; class Chinese : public Human { public: void eating(void) { cout << "use chopstick to eat" << endl; } };
然后我在global space中实现,对于不同国家的人有不同的吃饭方式这样一个函数。
void test_eating(Human& h) { h.eating(); }
现在,我还想分辨这个人是英国人还是中国人。那么,我该怎么做呢?
void test_eating(Human& h) { Englishman* pe = NULL; Chinese *pc = NULL; h.eating(); if ( pe == dynamic_cast < Englishman* > ( &h ) ); cout << "this is Englishman" << endl; if ( pc == dynamic_cast < Chinese* > ( &h ) ) cout << "this is Chinese" << endl; }
在test_eating()函数中,我先定义两个变量,分别指向Englishman*和Chinese类型。那么,它是如何动态转换的呢?当一个类中有虚函数时,根据该类所创建的类对象中就会有一个指针,这个指针指向虚函数表,这个虚函数表中,含有类信息,根据这个类信息,就知道这个对象是属于哪个类的。所以,这个类信息就可以确定Human& h的h,是哪个类的。
最后,静态类型转换static_cast<>在进行上行转换时,是安全的。而在下行转换时,没有动态的检查,所以是不安全的,只有你编写代码时去检查是否符合逻辑。