C语言基础篇(一)
一.数制
计算机只能识别0和1,所有数据在计算机中以二进制形式存储,想要学好计算机就要先掌握数制间的转换。常见的数制有二进制,八进制,十进制,十六进制。
1.十进制转为二进制
a.写出2^n
b.用所求十进制数与2^n比较,若大于等于记1,减去2^n,小于记0
c.所得数再与2^(n-1)比较(同第二步),直至n为0
例:100转换为二进制
100<2^7 0
100>2^6 1
100-2^6=36>2^5 1
36-2^5=4<2^4 0
4<2^3 0
4>=2^2 1
4-2^2=0<2^1 0
0<2^0 0
所以100的二进制为1100100
2.二进制转为十进制
用二进制每一位乘2^然后相加
例:1100100转为十进制
1*2^6+1*2^5+0*2^4+0*2^3+1*2^2+0*2^1+0*2^0=100
3.十进制转为其它进制
a.先将十进制转为二进制
b.由后往前每三位二进制转为十进制当作八进制的一位,高位不够补0
由后往前每四位二进制转为十进制当作十六进制的一位,高位不够补0
二.码制
数据在计算机中以补码的形式存储,所以我们要掌握原码,反码,补码之间的转换。
原码:在二进制数前加一个符号位,0表示正数,1表示负数。
反码:正数的反码是它本身,负数的反码是除符号位取反。
补码:正数的补码是它本身,负数的补码是反码加1。
例1:100的原码,反码,补码
原码:01100100
反码:01100100
补码:01100100
例2:-100的原码,反码,补码
原码:11100100
反码:10011011
补码:10011100
三.数据类型
C语言中类型分为基本类型,枚举类型,空类型,派生类型。基本类型又分为整型和浮点型。本文主要讲述整型,其他类型后续会讲。
| 整型 | 大小/字节 |
|---|---|
| float | 1 |
| short | 2 |
| int | 2/4 |
| long | 4 |
| long long | 8 |
int的大小由编译器决定,16位编译器上为2字节,32位编译器为4字节。
(这里以char为例讲解整型)
a.整型分为无符号和有符号,无符号的取值范围为0~255,有符号的取值范围为-128~127
int main()
{
char a;
for(a=0;a<128;a++)
{
printf("%d",a)
}
return 0;
}
int main()
{
unsigned char a;
for(a=0;a<128;a++)
{
printf("%d",a)
}
return 0;
}
这两个程序运行结果有什么区别?
第一个程序进入死循环,因为它定义的是有符号的char,最大为127,无法退出循环。
第二个程序定义的是无符号char,所以它输出了0~127.
563

被折叠的 条评论
为什么被折叠?



