温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

C++类型转换

发布时间:2020-06-28 12:20:19 来源:网络 阅读:459 作者:BarnabyRoss 栏目:编程语言

   C语言中,存在强制类型转换的概念。在C++中,C的做法同样适用。但是,C++也有自己的类型转换的方式,就是使用reinterpret_cast<>。例如,

char* str = "chentong";
int* p = reinterpret_cast<int*>(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<>在进行上行转换时,是安全的。而在下行转换时,没有动态的检查,所以是不安全的,只有你编写代码时去检查是否符合逻辑。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI