代码熟悉整型提升与unsigned signed

简介: 代码熟悉整型提升与unsigned signed

目录

🎉写在前面

🎨代码一

🎲代码二

🏆 代码三

🏐代码四

🎄代码五

✨ 代码六

🎈代码七

🎃总结


🎉写在前面

unsgned是无符号,signed是有符号,如果没加unsigned或signed一般变量都是默认sigend

整型提升:有符号的高位补符号位,无符号的高位补0

%d:%d是10进制打印有符号的整数

%u:%u是10进制打印无符号的整数

🎨代码一

我们可以知道a,b都是有符号的-1,所以它们的结果一样。c是无符号的-1,在截断的时候符号位也变成数值位了。我们还知道 %d是10进制打印有符号的整数,又因为他们是char变量,就需要整型提升

进行分析

🎲代码二

这里我们要注意,%u是10进制打印无符号的整数,且a是有符号的char类型,所以存入a中需要发生截断

进行分析

🏆 代码三

我们可以发现代码三和代码二非常相识,就是将-128改成了128。我们可以发现128存入char a中的二进制和-128存入char a中的二进制一摸一样。我们猜它们的结果是不是一样呢,下面我们进行分析。

进行分析

🏐代码四

这里先是以补码的形式计算,在转化为原码,再看打印的符号

进行分析

🎄代码五

我们可以知道,i从9到0是不会变打印的,一旦它到了负数,因为i是无符号整数,所以i在转化后都是正数,这个循环会一直进行下去,%u是打印无符号的10进制,它的结果就会大变样了。

进行分析

✨ 代码六

这里我们要注意有符号的char类型的大小-128~127,strlen遇到'\0'就会停下来,'\0'的ASCII码值是0

进行分析

🎈代码七

我们注意到i是unsigned char类型的,所以它的范围是0~255,我们还要注意跳出循环的条件是i>255

进行分析


🎃总结

通过上面这些代码的案例的分析和讲解,想必大家对整型提升和unsigned signed的区分和理解已经拔高了一个层次了叭。通过这些代码,我们得明白,想要提高代码水平,我们还是要回归到实践当中 ,通过敲代码的方式直接的去感受代码,联系自己所学的知识点去理解代码,进而又加深了对知识的理解。

目录
相关文章
|
5月前
|
存储 自然语言处理 编译器
C语言中的char类型
C语言中的char类型
428 1
|
7月前
|
C语言
C语言-----计算两个int(32位)整数m和n的二进制表达中,有多少个位(bit)不同?
C语言-----计算两个int(32位)整数m和n的二进制表达中,有多少个位(bit)不同?
|
8月前
|
C语言
C语言(8)----长度计算方法:sizeof与strlen的对比
C语言(8)----长度计算方法:sizeof与strlen的对比
46 0
|
8月前
|
C语言
[C语言][题]两个int(32位)整数m和n的二进制表达中,有多少个位(bit)不同。
[C语言][题]两个int(32位)整数m和n的二进制表达中,有多少个位(bit)不同。
52 1
|
8月前
|
存储 编译器 程序员
learn_C_deep_4 (类型和变量命名、sizeof(int) *p表示什么意思、原码、反码和补码的概念、计算机中数据计算时,为什么要转为二级制、unsigned和signed关键字)
learn_C_deep_4 (类型和变量命名、sizeof(int) *p表示什么意思、原码、反码和补码的概念、计算机中数据计算时,为什么要转为二级制、unsigned和signed关键字)
|
存储 小程序 程序员
8k字详解整型(int)/字符型(char)/浮点型(float)/有符号(signed)/无符号(unsigned)数据在内存中的存储【程序员内功修炼/C语言】
8k字详解整型(int)/字符型(char)/浮点型(float)/有符号(signed)/无符号(unsigned)数据在内存中的存储【程序员内功修炼/C语言】
221 0
|
存储 C语言
C语言:char与unsigned char类型数据的范围
unsigned char 的范围是 0~255,当 i=255 时,i++变为0,从0到255无限循环,因此程序运行结果为死循环
425 0
|
存储 编译器 C语言
C语言中unsigned int a=-10,这种写法是否正确?
C语言中unsigned int a=-10,这种写法是否正确?
137 0
|
存储 编译器 C语言
unsigned 无符号是什么?
unsigned 无符号是什么? 数据是如何储存的 什么叫无符号
93 0

热门文章

最新文章