现在有一排水桶,一共有0xFFFFFFFF 个,编号为0--0xFFFFFFFF,每个水桶的容量是8升,
现在如果 想一次取水 3升, 那么随便选择一个水桶(比如是第32号水桶),注入水.
因为所有的水桶看起来都一样,我们不太容易知道是哪个编号的位置里装水了,
为了跟没有装水的水桶区别开来,我们在这个第32号装了水的水桶上贴个标签叫 "xiaoming".
那么这个时候从一排水桶里边找我们的第32号水桶就方便多了.
有时候我们需要一次性装入32升水,那简单, 直接找4个水桶啊. 然后在这4个水桶上 用胶带粘起来整体作为一个基本单位,贴个标签,叫做 "xiaoliang".
在这里,这一排水桶就是内存,, 一个水桶就是 基本数据类型种的 char, 4个水桶作为一个整体就是int,
这个"xiaoming" , "xiaoliang" 就是变量的名字.
C 语言数据类型 包含 基本数据类型和构造类型,指针类型和空类型.
如下:
看了上边,会不会觉得很复杂 ?
其实常用的也就只有 char ,int , float, double, 以及以上几种的组合构造类型而已.
一般而言, 长整形至少 和整形一样长,整形至少和短整形一样长.
long >= int >= short
char 为一个字节(8位), int 一般和cpu 的机器字长, 通常由编译器决定.
通常用 sizeof 操作符来确定 具体字节.
以下代码可用于 确定 具体字节:
#include<stdio.h>
int main(int argc ,char * argv[])
{
printf("char : %d 个字节,%d 位 \n",sizeof(char),8*sizeof(char));
printf("short : %d 个字节 %d 位 \n",sizeof(short),8*sizeof(short));
printf("int : %d 个字节,%d 位 \n",sizeof(int),8*sizeof(int));
printf("long : %d 个字节,%d 位 \n",sizeof(long),8*sizeof(long));
printf("float : %d 个字节,%d 位 \n",sizeof(float),8*sizeof(float));
printf("double : %d 个字节,%d 位 \n",sizeof(double),8*sizeof(double));
return 0;
}
以上 提到了变量的概念, 变量就是我们在初中学到的代数里边的概念, 就是 用一个字母来代替数字.
在C 语言里边, 变量就是这个作用,
char 型变量 就是来代表一个 字母,
int 型变量 就是来代表一个 整数, ( short,long 也是来代表一个 整数的, 只是表示范围不同).
float 型变量 就是来代表一个小数,
double 型变量 也是来代表一个小数,只不过它比 float 能表示的范围更大.
这里的表示范围跟什么有关系呢 ? 就是前边的具体字节.
我们平时使用的数字都是由 0~9 共十个数字组成的,例如 1、9、10、297、952 等,一个数字最多能表示九,如果要表示十、十一、二十九、一百等,就需要多个数字组合起来。
例如表示 5+8 的结果,一个数字不够,只能”进位“,用 13 来表示;这时”进一位“相当于十,”进两位“相当于二十。
因为逢十进一,也因为只有 0~9 共十个数字,所以叫做十进制(Decimalism)。
进制也就是进位制。在进行加法(减法)运算时,逢X进(借)一就是X进制,这种进制也就包含X个数字,基数为X。十进制有0~9共10个数字,基数为10,在加减法运算中,逢十进一,借一当十。
我们不妨将思维拓展一下,既然可以用 0~9 共十个数字来表示数值,那么也可以用0、1两个数字来表示数值,这就是二进制(Binary)。
二进制思想
二进制只有0和1两个数字,基数为2,在加减法运算中,逢二进一,借一当二。- 表示数值:0、1、10、111、100、1000001
- 加法:1+0=1、1+1=10、10+110=1000、111+111=1110、
- 减法:1-0=1、10-1=1、100-11=1、1010-101=101
要想学习编程,就必须了解二进制,它是计算机处理数据的基础。
内存条是一个非常精密的部件,包含了上亿个电子元器件,它们很小,达到了纳米级别。这些元器件,实际上就是电路;电路的电压会变化,要么是 0V,要么是 5V,只有这两种电压。5V 是通电,用1来表示,0V 是断电,用0来表示。所以,一个元器件有2种状态,0 或者 1。
我们通过电路来控制这些元器件的通断电,会得到很多0、1的组合。例如,8个元器件有 28=256 种不同的组合,16个元器件有 216=65536 种不同的组合。虽然一个元器件只能表示2个数值,但是多个结合起来就可以表示很多数值了。
我们可以给每一种组合赋予特定的含义,例如,可以分别用 1101000、00011100、11111111、00000000、01010101、10101010 来表示 C、语、言、中、文、网 这几个字,那么结合起来 1101000 00011100 11111111 00000000 01010101 10101010 就表示”C语言中文网“。
一般情况下我们不一个一个的使用元器件,而是将8个元器件看做一个单位,即使表示很小的数,例如 1,也需要8个,也就是 00000001。
1个元器件称为1比特(Bit)或1位,8个元器件称为1字节(Byte),那么16个元器件就是2Byte,32个就是4Byte,以此类推:
- 8×1024个元器件就是1024Byte,简写为1KB;
- 8×1024×1024个元器件就是1024KB,简写为1MB;
- 8×1024×1024×1024个元器件就是1024MB,简写为1GB。
现在