首先我们先确定几个基础的常识
1、计算机要处理的数据(诸如数字、文字、符号、图形、音频、视频等)是以二进制的形式存放在内存中的。
2、我们将8个比特(Bit)称为一个字节(Byte),并将字节作为最小的可操作单元。
3、计算机的进制是以1024为标准,1024B = 1K,1024K=1M,1024M=1G。
4、所谓的程序是我们要告诉计算机要按照什么样的思维方式来处理事情。
3、内存是计算机中重要的部件之一,它是与CPU进行沟通的桥梁,所有程序的运行都是在内存中进行的。
变量(Variable)
所谓变量相当于我们现实生活中的一个储物盒,我们要将具体的东西放到这个盒子内。计算机也是这个道理,我们需要先在内存中找一块区域,规定用它来存放数据,并起一个有含义的名字,方便以后查找。这块区域就是“储物盒”,我们可以把数据放进去。
数据类型(Data Type)
数据类型相当于我们之前所说储物盒的类型,例如是放首饰的,还是放衣服的,我们要规定好。计算机的数据是放在内存中的,变量是给这块内存起的名字,有了变量就可以找到并使用这份数据。那么我们如何使用呢?
之前我们提到的数字、文字、符号、图形、音频、视频等数据都是以二进制形式存储在内存中的,计算机是无法区别他们的具体形式的,计算机只会按照0101的二进制来看,所以计算机的世界里只有01两个数字。这就需要我们来为计算机确定一个“储物盒”类型,例如我想存储整数可以用int a,就表明,这个名字叫a的“储物盒”里存储的数据应该是一个整数,int 有一个专业的广义称呼,叫做数据类型(Data Type),具体的我们叫做整型(整数类型)。
在C语言中,有多种数据类型
数据类型的取值范围和长度:
所谓数据长度(Length),是指数据占用多少个字节。占用的字节越多,能存储的数据就越多,对于数字来说,值就会更大,反之能存储的数据就有限。
按照从小到大排列如下:
short <= int <= long <= long long
float <= double <= long double
到底是小于还是等于取决不同的操作系统,这一点可以用sizeof做测试,稍后我介绍用法。
在语言中我们在内存中设置一个变量名为a的"存储盒",它的存储的数据类型是整数,int我们叫整型,英文全称Integer,int这类的在开发环境中是可以自动识别到它的自身的含义的,这类的标示我们叫做关键字(系统定义的标识符),而变量的名字a,我们也可以取一个其他名字,a1,aa,abc等,这类我们叫做用户自定义标识符(一般名字取的要有一定含义,如int age,表示存储的是年龄的值)。
int a;
注意:
int 和 a 之间是有空格的,它们是两个词。也注意最后的分号,int a表达了完整的意思,是一个语句,要用分号来结束。
ps:用户自定义标识符
1.标识符必须以字母a~z、 A~Z或下划线开头,后面可跟若干个字符,这些字符可以是字母、下划线和数字,其他字符不允许出现在标识符中。
2.标识符区分大小写字母。
3.标识符的长度,c89规定31个字符以内,c99规定63个字符以内。
4.C语言中的关键字,保留字,有特殊意义,不能作为标识符
5.自定义标识符最好取具有一定意义的英文简写组成,便于记忆。
现在我们来看如何将数据放进变量中
两种方式:
1、初始化赋值,好比拿来一个盒子,这个盒子本来就自带一些东西存放在里面。
定义一个变量a,它存放的数据类型是int整型数据,在定义的同时将数值1赋值给变量a存储," = "代表赋值的意思,不是等于。
int a = 1; //初始化赋值
2、先定义,再使用。好比先准备一个空盒子,然后再将东西放进去。
定义一个int类型的变量a,在第二个语句再对变量a进行赋值1的操作,第三个语句对变量a再次赋值,将之前的1值覆盖掉,最终a存储是100
int a; //定义变量a
a = 1; //对变量a赋值1
a = 100; //对变量a再次赋值100
连续定义多个变量
为了让程序的书写更加简洁,C语言支持多个变量的连续定义
int a, b, c;
float m = 10.9, n = 20.56;
char p, q = '@';
连续定义的多个变量以逗号,分隔,并且要拥有相同的数据类型;变量可以初始化,也可以不初始化。
ps:注意输入法要用英文输入法,否则输入中文的逗号,分号程序编译报错。
总结
数据是放在内存中的,在内存中存取数据要明确三件事情:数据存储在哪里、数据的长度以及数据的处理方式。
变量名不仅仅是为数据起了一个好记的名字,还告诉我们数据存储在哪里,使用数据时,只要提供变量名即可;而数据类型则指明了数据的长度和处理方式。所以诸如int n;、char c;、float f; 这样的形式就确定了数据在内存中的所有要素。
数据类型只在定义变量时指明,而且必须指明;使用变量时无需再指明,因为此时的数据类型已经确定了。如:
int a = 1;
int a = 100;//错误的操作