C++(4个类型转换)

发布于:2024-12-07 ⋅ 阅读:(136) ⋅ 点赞:(0)
1. C语言中的类型转换
1. 隐式 类型转换: 具有相近的类型才能进行互相转换,如:int,char,double都表示数值。
2. 强制类型转换:能隐式类型转换就能强制类型转换,隐式类型之间的转换类型强相关,强制类型转换之间类型关联没有那么大,如:整形和指针,指针与指针。

int main()
{
	int a = 0;

	// 隐身类型转换
	char b = a;
	int c = b + a;

	// 强制类型转换
	double* d = (double*)a;
		
	double* p = new double;
	int* h = (int*)p;

	return 0;
}

3.缺点:转换的可视性比较差,所有的转换形式都是一样的,不好排查错误。  

2. C++支持的类型转换

1. 兼容C语言的所有转换。

2. 支持内置类型转自定义类型,如:单/多参数的构造函数支持隐式类型转换。

3. 支持自定义类型转内置类型,

4. 支持自定义类型转自定义类型

class A
{
public:
	A() {}
	A(int i) {}
	// explicit 可以不让隐式类型转换
	// explicit A(int i, int j) {}
	A(int i, int j) {}
	
	// 自定义类型转内置类型
	operator int()
	{
		_code = 10;
		return _code;
	}

	int _code;
};

class B
{
public:
	B(const A& a) {}

};
int main()
{
	// C++98 单参数构造
	A a1 = 1;
	// C++11 多参数构造
	A a2 = { 1,2 };
	// 自定义类型转内置类型
	int k = (int)a1;
	// 自定义类型转自定义类型
	B b = a1;
	return 0;
}
3. C++4种强制类型转换(标准C++为了加强类型转换的可视性,引入了四种命名的强制类型转换操作符)

1. static_cast(隐式类型转换)

2. reinterpret_cast(强制类型转换)

int main()
{
	int a = 0;

	// 隐身类型转换
	char b = static_cast<int>(a);
	int c = static_cast<int>(b) + a;

	// 强制类型转换 
	double* d = reinterpret_cast<double*>(a);
		
	double* p = new double;
	int* h = reinterpret_cast<int*>(p);

	return 0;
}

3. const_cast(删除变量的const属性)

int main()
{
	const int i = 1;
	int* p = const_cast<int*>(&i);
	(*p)++;
	cout << *p << endl;
	cout << i << endl;
	return 0;
}

虽然 i 是const修饰的,但i本身还是在栈区,只是属性是const(常变量),可以用强制转换成指针

但打印出来的结果不对劲,因为被const修饰了,编译器默认他不会修改,直接放到寄存器里,下次取数据直接拿寄存器里面的,不会到内存里拿。

加上volatile关键字让编译器去内存里取数据

4. dynamic_cast(用于将一个父类对象的指针/引用转换为子类对象的指针或引用(动态转换))

1. 只能用于父类含有虚函数的类。
2. 会先检查是否能转换成功,能成功则转换,不能则返回 0。
dynamic_cast 则会检查能否转换成功,指向子类成功,指向父类失败

网站公告

今日签到

点亮在社区的每一天
去签到