C/C++:类型转换
最近复盘C基础发现类型转换看着简单实际细碎考点非常多。很多代码写法平时随手就能写但一深挖底层编译逻辑就容易混乱。我把整套知识点按步骤拆解、条理化整理配上完整可运行代码全程条目化讲解适合自用复盘、考前快速背诵。一、C 语言隐式类型转换底层原理先从最基础的 C 语言入手所有 C 类型转换都是基于这一套规则延伸出来的。int a 100; double b a; short c a;1、核心前提不同类型能够发生隐式转换不是随机行为必须满足同一个条件底层二进制存储结构相似、数据用途一致。2、为什么数值类型可以互转char、short、int、double 全部都是纯数值类型底层都是二进制存数用途都是运算、赋值、传参属性高度统一。3、编译器行为只要类型相似编译器自动完成类型对齐、自动补齐位数、自动适配精度不需要手动强转。补充C 完全继承 C 语言这套原生隐式转换规则没有改动只是额外扩展了「类类型」的转换能力。二、内置类型 → 自定义类类型转换C 新增关键能力普通数字可以直接隐式转成对象。类没有二进制相似性所以类的所有隐式转换全部靠构造函数实现。1单参隐式转换完整流程先写基础测试类观察构造、拷贝构造的调用时机#include iostream using namespace std; class A { public: A(int x) { cout 执行普通构造 A(int) endl; } A(const A) { cout 执行拷贝构造 A(const Aamp;) lt;lt; endl; } };测试代码A a1 1;✅ 语法逻辑层面固定分为 1、2 两步缺一不可1、生成临时对象右边是 int 数字 1左边是类对象类型不匹配。编译器自动调用A(int)构造函数用数字生成一个匿名临时对象。2、拷贝构造目标对象用刚才生成的临时对象调用拷贝构造初始化实体对象 a1。补充按标准 C 语法理论上一定会走普通构造 拷贝构造 两次调用。✅ 实际运行为什么看不到拷贝构造编译器优化机制1、编译器检测冗余动作先造临时、再拷贝属于多余开销没有实际意义。2、自动合并构造流程编译器直接把两步合并成一步不在额外创建临时对象。3、原地直接构造对象直接在 a1 的内存空间里用数字 1 直接构造对象省略拷贝。2const 引用绑定临时对象const A a2 2;1、先构造临时对象用整数 2 调用构造函数生成一个临时的类对象。2、引用直接绑定临时对象引用只是别名不分配新内存不创建新对象自然不需要拷贝构造。3、必须加 const 修饰临时对象具有只读属性普通引用不能绑定只有 const 引用可以安全绑定。补充这个写法天生没有拷贝不需要编译器优化开销最低平时可以多用。3多参数隐式类型转换分步 避坑重点class B { public: B(int a, double b) { cout 多参构造执行完成 endl; } };✅ 正确写法步骤B b {10, 3.14};1、使用花括号{}包裹多个数值2、编译器识别为多参数入参3、直接匹配多参构造函数转换成功。❌ 错误写法B b (10, 3.14);1、小括号内的逗号不是参数分隔符2、编译器解析为逗号表达式3、最终只保留最后一个数值参数数量不匹配直接编译报错。注硬性规则多参数隐式转换只允许 {}绝对不能用 ()。三、类与类之间隐式转换class Student { public: string name; Student(string n) : name(n) {} }; class Person { public: Person(const Student s) { cout 跨类转换完成 s.name endl; } }; int main() { Student s(小明); Person p s; return 0; }1、识别类型不匹配右边是 Student左边是 Person类型不一样。2、寻找适配构造函数编译器在 Person 类中查找参数为 Student 的构造函数。3、自动完成隐式转换调用构造函数把 Student 对象的数据拷贝过来完成跨类转换。补充想让 A 类转 B 类只需要在 B 类中写一个参数是 A 的构造函数即可。四、关闭隐式类型转换默认情况下构造函数会自动触发隐式类型转换。如果不想让编译器偷偷自动转换避免代码出现隐性逻辑问题直接用explicit关键字就行。1、使用方式直接在单参构造函数、多参构造函数前面加上 explicit。2、核心效果1、加了 explicit 后编译器禁止自动隐式类型转换2、像 A a 1; 这种写法会直接报错3、不会彻底禁用转换只是必须手动显式调用构造函数创建对象。注关闭隐式类型转换后还想进行转换可以这么写// 手动显示调用构造合规合法不会报错 A a A(1); // 或者直接括号初始化 A a2(2);五、总结1、C 语言隐式转换核心类型底层存储、用途相似编译器自动转换C 完全兼容。2、内置类型转类靠单参构造逻辑上分两步构造临时对象 拷贝构造编译器会优化为直接构造。3、const 引用绑定临时对象引用不产生新对象无拷贝开销const 适配只读属性。4、多参数转换只能用 {}不能用 ()防止逗号表达式导致编译失败。5、类与类转换在目标类中添加对应源类的构造函数自动完成隐式转换。6、终极结论C 所有类相关类型转换全部依靠构造函数完成。
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2558414.html
如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!