【C语言】unsigned无符号类型运用的两个实例
@[toc]
前排提醒😂
本篇博客是对下一篇博客《char类型在内存中的存放》的拓展
并非对unsigned类型的详解!
示例1
1 |
|
当有符号类型和无符号类型相加的时候,编译器是怎么处理的呢?
1 | 10000000 00000000 00000000 00010100 -20的原码 |
1 | 00000000 00000000 00000000 00001010 10的补码 |
-20的补码和10的补码 相加
1 | 11111111 11111111 11111111 11110110 得到的补码 |
得到的结果为-10
当我们把j改为-10的时候,编译器依然能给出正确的答案-30
这是因为在计算的时候,编译器先按照补码的形式进行运算,最后%d打印,格式化为有符号整数
- 数据的存储和类型无关,只有读取的时候有区别
示例2
第二个示例可以让我们了解无符号数在应用时候存在的限制
1 |
|
因为这里我们使用的是%u打印无符号数
而无符号数i中不可能出现负数,也就没有小于0的情况(i永远大于等于0)
当i=0后继续–,二进制补码变成如下形式
1 | 11111111 11111111 11111111 11111111 |
因为是无符号数,直接将补码视作原码进行计算
就得出了在窗口中打印的非常大的数字
小结
本篇博客展示了两种无符号数调用的情况
下篇博客讲述char类型在数据中的存储的时候会用到!
最近事情真的挺多的,英语4级、期末考试
高数和线代真的太难了,两座大山压着我😥
希望期末不挂科
感谢你看到最后,求点赞关注!
- 本文标题:【C语言】unsigned无符号类型运用的两个实例
- 创建时间:2021-12-13 22:14:28
- 本文链接:posts/26306730/
- 版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!