一道简单易错笔试题
2015-01-27 13:00
218 查看
#include<stdio.h>
int main(int argc, char* argv[])
{
char c=128;
printf("十进制c=%d\n",c);
printf("十六进制c=0X%0X\n",c);
return 0;
}
结果为
十进制c= -128;
十六进制c=0XFFFFFF80;
解析:
128的十六进制是0x80, 也就是2^7, 二进制看起来像这样:1000 0000 ,赋值给有符号数char c,其二进制不变。
但是小于sizeof(int)的整数在使用时其实都是扩展到sizeof(int)再计算的,对于有符号数扩宽填充符号位,这里char c=128的符号位是1,所以就是扩充了1111 1111 1111 1111 1111 1111 1000 0000,这样,打印%x时候,就是你看到的结果了。
这个扩宽是很正常的,并不会影响一个数值本身, 只是存储的字节变宽了而已。
符号位为1的二进制转十进制负数
①除去符号位减1;
②除去符号位,按位取反;结果就是负数的源码;
③源码转成相应的十进制。
因为符号位为1,所以被当做负数,而负数是以补码形式存在的,
所以其反码是1111 1111 1111 1111 1111 1111 1000 0000 - 1=1111 1111 1111 1111 1111 1111 0111 1111
原码是 1000 0000 0000 0000 0000 0000 1000 0000 转化为十进制是-128。
int main(int argc, char* argv[])
{
char c=128;
printf("十进制c=%d\n",c);
printf("十六进制c=0X%0X\n",c);
return 0;
}
结果为
十进制c= -128;
十六进制c=0XFFFFFF80;
解析:
128的十六进制是0x80, 也就是2^7, 二进制看起来像这样:1000 0000 ,赋值给有符号数char c,其二进制不变。
但是小于sizeof(int)的整数在使用时其实都是扩展到sizeof(int)再计算的,对于有符号数扩宽填充符号位,这里char c=128的符号位是1,所以就是扩充了1111 1111 1111 1111 1111 1111 1000 0000,这样,打印%x时候,就是你看到的结果了。
这个扩宽是很正常的,并不会影响一个数值本身, 只是存储的字节变宽了而已。
符号位为1的二进制转十进制负数
①除去符号位减1;
②除去符号位,按位取反;结果就是负数的源码;
③源码转成相应的十进制。
因为符号位为1,所以被当做负数,而负数是以补码形式存在的,
所以其反码是1111 1111 1111 1111 1111 1111 1000 0000 - 1=1111 1111 1111 1111 1111 1111 0111 1111
原码是 1000 0000 0000 0000 0000 0000 1000 0000 转化为十进制是-128。
相关文章推荐
- 一道简单笔试题
- 一道google笔试题的简单分析
- 一道简单的笔试题
- 一道“简单”的笔试题 (c /c++ ,汇编)
- 一道超经典且易错的笔试题
- 关于大小端和union的一道极易错的笔试题
- 一道简单的字符指针笔试题
- 一道简单的google笔试题
- 一道简单又不简单的算法笔试题
- 偶见一道华为笔试题(简单的题更显算法啊--不可忽视的数学)
- 一道简单的笔试题
- 今天面试笔试了一道SQL面试题,狠简单
- JAVA枚举的一道简单的笔试题
- 一道简单的C++笔试题,关于抽象shape类求图形周长的问题~
- 一道看似简单的易错数分考研题
- 一道智力题(某公司笔试题)
- 参加Grapecity的一道笔试题
- 一道微软MiniTest笔试题
- 简单一道排序题,考倒多少读书人!