c++中的类型转换及volatile(从语音层面看)

C++强制类型转换

标准C++为了加强类型转换的可视性,引入了四种命名的强制类型转换操作符:

static_cast、reinterpret_cast、const_cast、dynamic_cast

复制代码
#include<iostream>
using namespace std;


int main()
{
	int i = 1;
	double d = 6.66;
	//c---隐式转换
	i = d;
	cout << i << endl;//6
	//c---显式转换
	int* p = nullptr;
	p = (int*)i;
	cout << p << endl;//6
	//c++---c>隐式转换
	d = static_cast<double>(i);
	cout << d << endl;//6
	//c++---c>显式转换
	p = reinterpret_cast<int*>(i);
	cout << p << endl;//6
	//const_cast --- 去const属性
	const int ci = 10;
	int* pi = const_cast<int*>(&ci);
	*pi = 20;
	cout << *pi << endl;//20
	//编译器对const对象存取优化导致---内存中ci为20寄存器中ci为10
	cout << ci << endl;//10
	//防止优化,让编译器从内存中取值
	volatile const int ci = 10;
	int* pi = const_cast<int*>(&ci);
	*pi = 20;
	cout << *pi << endl;//20
	cout << ci << endl;//20

	return 0;
}

//注:dynamic_cast向下转换只能针对继承中的多态类型(父类必须包含虚函数)

复制代码
///
class A {
public:
	virtual void f()
	{} 

	int _a;
};
class B : public A
{
public:

	int _b;
};
void f_cast(A* pa)
{
	//如何判断pa是指向父类对象还是指向子类对象???
	//dynamic_cast ---若pa指向子类对象,则转换成功
	//             ---若pa指向父类对象,则转换失败,并返回nullptr
	//B* pb = (B*)pa;
	B* pb = dynamic_cast<B*>(pa);
	if (pb != nullptr)
	{
		cout << "转换成功: pa指向子类对象" << endl;
		pb->_a = 1;
		pb->_b = 2;
	}
	else
	{
		cout << "转换失败: pa指向父类对象" << endl;
	}
}

 //注:dynamic_cast向下转换只能针对继承中的多态类型(父类必须包含虚函数)
A a;
B b;
A* pa = &a;
//f_cast(pa);
pa = &b;
f_cast(pa);

向上转换:

c++中子类对象可以赋值给父类的对象,指针,引用,这个过程会发生切片,语法天然支持,不然可以转换成功。

向下转换:

如果是父类的指针或引用,传给子类的指针,这个过程不一定成功。

相关推荐
Elias不吃糖3 小时前
Java Lambda 表达式
java·开发语言·学习
guygg884 小时前
一级倒立摆MATLAB仿真程序
开发语言·matlab
暮色_年华4 小时前
随想 2:对比 linux内核侵入式链表和 STL 非侵入链表
linux·c++·链表
情缘晓梦.4 小时前
C语言指针进阶
java·开发语言·算法
世转神风-4 小时前
qt-字符串版本与数值版本互转
开发语言·qt
极客代码5 小时前
深入解析C语言中的函数指针:原理、规则与实践
c语言·开发语言·指针·状态机·函数·函数指针
w-w0w-w5 小时前
C++模板参数与特化全解析
开发语言·c++
不绝1915 小时前
C#核心:继承
开发语言·c#
大锦终6 小时前
递归回溯综合练习
c++·算法·深度优先