正数+相反数=0
所以负数的补码为:0-正数
考虑一个八位的数,0的表示方法
0000 0000 => 1111 1111 + 1
所以负数的补码 = (1111 1111 + 1) -(正数)
eg:5 0000 0101
-5 = (1111 1111 + 1)-(0000 0101)= (1111 1111 - 0000 0101) + 1
结论就是我们之前一直都知道的:
负数的补码为:正数按位求反后加一
=>按位取反后加一,其实就是求相反数。
求:负数 1011 1110代表十进制多少
2)截断。将长的数据类型存放到短的数据类型中,就会发生截断
用二进制理解:截断时,将高位丢弃,只保留低位的。
扩充:如果是正数,高位扩充为0;如果是负数,高位被扩充为符号位
eg:
char ch = 190;
char uch = 190// 1011 1110
printf("%d %d",ch,uch);//
结果:-66 190
3)
int num = 0;//num为局部变量
int num1 = 0;
num1 = num++ + ++num;//num的值前后一样,为++num的结果
printf("%d%d",num,num1);
在我的编译器中答案是:2 2
但是将num定义为全局变量后,num1的结果却为5
所以在同一个表达式中执行多次自增和自减,结果是未知的。
4)输入输出格式控制
char -- %c
short -- %hd
unsigned short -- %hu
long -- %ld
unsigned long -- %lu
int -- %d
unsigned int -- %u
float -- %f或%g
double -- %lf或%lg 区别:lg会将小数点后面无效的0去掉 eg: printf("%lg",3.2); 为3.2 。printf("%lf",3.2);则为3.200000
占位符特殊用法
%3d 数字占3个位置,数字从最后边位置输出,如果数字小于三位书,则左边用空格填充 --8 //输出数字8,左边补空格
%-3d 数字占3个 位置,数字从最左边的位置开始输出 8-- //右边补空格
%03d 数字占3个位置,空的用0填充 008 //左边补0
%7.2f 一共占7个位,小数点占2个位置