为什么带符号的1字节最大表示(127),最小可以表示(-128)
最左边的一位如果是1就代表的是负数,如果是0就是正数
(1000 0000)== -128
(0111 1111)== 127
带符号的1字节(unsigned char)如果用二进制表示十进制的5;
二进制(0000 0101) == 十进制 5;
那负5如何表示呢?//把每位按位取反加1;
先取反(1111 1010),再加1;
就是(1111 1011) == -5
带符号的类型如果表示正整数,左边最高位一定是0
带符号的类型如果表示负整数,如果不够位数就往左补1,左边最高位一定是1
#include<stdio.h>
int main (void)
{
unsigned int ch = 5;//用的是4字节的int类型
unsigned int ff = -5;
printf("正5的十六进制%#xn",ch);
printf("负5的十六进制%#xn",ff);
return 0;
}
//C语言没有二进制输出,所以就用十六进制给演示了
十六进制转二进制小技巧
十六进制内的数字表示(0,1,2,3,4,5,6,7,8,9,A,,B,C,D,E,F)
下面是4字节的二进制码
(1111 1011 1110 0000 1101 0001 1100 0010)
转换以后的16进制码
(F B E 0 D 1 C A)
4位二进制等于1个十六进制来计算会更容易理解
C语言中0X代表的是16进制输出
程序输出如下
正5的十六进制0x5
负5的十六进制0xfffffffb
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。