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

向下转换:

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

相关推荐
观音山保我别报错9 分钟前
列表,元组,字典
开发语言·python
**蓝桉**20 分钟前
数组的执行原理,java程序的执行原理
java·开发语言
waeng_luo32 分钟前
[鸿蒙2025领航者闯关] 表单验证与用户输入处理最佳实践
开发语言·前端·鸿蒙·鸿蒙2025领航者闯关·鸿蒙6实战·开发者年度总结
高频交易dragon35 分钟前
5分钟和30分钟联立进行缠论信号分析
开发语言·python
ULTRA??37 分钟前
C/C++函数指针
c语言·开发语言·c++
还没想好取啥名38 分钟前
C++11新特性(一)——自动类型推导
开发语言·c++·stl
我是华为OD~HR~栗栗呀41 分钟前
华为OD-C面经-23届学院哦
java·c++·python·华为od·华为·面试
xiaozi41201 小时前
Ruey S. Tsay《时间序列分析》Python实现笔记:综合与应用
开发语言·笔记·python·机器学习
西贝爱学习1 小时前
Visual Studio下载地址,vs2022安装程序
c++
天赐学c语言1 小时前
12.5 - 二叉树的最近公共祖先 && 构造函数和析构函数可以是虚函数吗
c++·二叉树·虚函数