个人理解|【C语言基础之类型转换】

【个人理解|【C语言基础之类型转换】】全寝室最接地气的有关类型转换的介绍,此处对于类型转换的相关知识点做一些简要的介绍,作者实属初学,写博客也是作者学习的一个过程,难免文章中有内容理解不到位或者有不当之处,还请朋友们不吝指正,希望大家多多给予支持,赠人玫瑰,手有余香!

文章目录

  • 类型转换
    • 隐式类型转换
    • 强制类型转换

类型转换 数据有不同的类型,不同类型数据之间进行混合运算时必然涉及到类型的转换问题。转换包括隐式类型转换和强制类型转换。
类型转换的原则:占用内存字节数少(值域小)的类型,向占用内存字节数多(值域大)的类型转换,以保证精度不降低。
个人理解|【C语言基础之类型转换】
文章图片

隐式类型转换 隐式转换也称为自动转换,遵循一定的规则,由编译器自动完成。
C的整型算数运算总是至少以缺省整型类型的精度来进行,为了获得这个精度,表达式中的字符和短整形操作数在使用之前都被转换成普通整型,这种转换为整型提升。
整型提升:通用CPU是难以直接实现两个8比特位直接相加运算。所以表达式中各种长度可能小于int长度的整型值,都必须转换为int或者unsigned int ,然后才能送入CPU去执行运算。
代码示例1:
int main() { char a = 5, b = 126; //5:00000000 00000000 00000000 00000101 //a:0000 0101(截断操作) //126:00000000 00000000 00000000 01111110 //b:0111 1110 //当a和b相加时,都是char类型,就会发生整型提升 //int c = 000000000000000000000000 00000101 + 000000000000000000000000 01111110 //char c = 10000011(整型截断) //以%d 打印,再次在内存中整型提升,再打印原码 //int c = 11111111111111111111111110000011(补码) //打印原码:10000000000000000000000011111101 char c = a + b; printf("%d\n", c); return 0; }

个人理解|【C语言基础之类型转换】
文章图片

**如何整型提升:**按照变量的数据类型的符号位来提升。
代码示例2:
//负数的整型提升 char s1 = -1; 变量s1的二进制补码中只有8个比特位 11111111 因为char是有符号的,所以在整型提升的时候,高位补充符号位 即:11111111 11111111 11111111 11111111//正数的整型提升 char s2 = 1; 变量s2的二进制补码中只有8个比特位 00000001 因为char是有符号的,所以在整型提升的时候,高位补充符号位 即:00000000 00000000 00000000 00000001

无符号数的整型提升,高位直接补0;
代码示例3:
隐式转换
int main() { int num = 5; printf("s1=%d\n", num / 2); printf("s2=%lf\n", num / 2.0); return 0; }s1=2 s2=2.500000 请按任意键继续. . .

强制类型转换 强制类型转换指的是使用强制类型转换运算符,将一个变量或表达式转化成所需的类型
代码示例1:
#include int main() { float x = 0; int i = 0; x = 3.6f; i = x; //x为实型, i为整型,直接赋值会有警告 i = (int)x; //使用强制类型转换 printf("x=%f, i=%d\n", x, i); return 0;

OK!!!观众老爷们,这里只是介绍了有关类型转换的入门知识,如果朋友们觉得有一点点作用的话,希望朋友们能够给予小菜鸟一点支持!后续继续给朋友们带来更好的博文,还希望朋友们能够继续关注,小菜鸟致力于把自己的学习经验与个人理解更多的分享给大家,望大家喜欢与指正。谢谢谢谢谢谢谢谢谢谢谢谢谢谢谢谢谢谢谢谢谢谢谢谢谢谢谢谢谢谢

    推荐阅读