一、变量
a = 123;
- 在C语言中,"="的作用是赋值,赋值是指把数据存放到内存中的过程。
int a = 123;
a = 1000;
a = 9999;
- a的值可以改变,所以我们给它起了一个形象的名字叫做变量。
- int a; 创建了一个变量a,我们把这个过程称为变量定义。
- a = 123;把123交给了变量a,我们把这个过程叫做给变量赋值;有因为是第一次赋值,所以也叫作变量的初始化,或者赋初值。
二、数据类型
- 数据类型用来说明数据的类型,确定了数据的解释方式,让计算机和程序员不会产生歧义。
- C语言中有以下数据类型:
- 另外,数据长度是指数据占用多少个字节。
- 在C语言中,每一种数据类型占用的字节数都是固定的,知道了数据类型,也就知道了数据的长度。
- 数据类型只在定义变量时指明,而且必须指明;使用变量时无需再指明,因为此时的数据类型已经确定。
三、输出数据
printf("格式化输出");
- printf是print format的缩写,意思是“格式化输出”,即在屏幕上显示内容。
int a = 100;
int b = 200;
int c = 300;
printf("a = %d,b = %d,c = %d",a,b,c);
- %d与后边的变量是一一对应的,第一个%d对应第一个变量,第二个%d对应第二个变量······
- %d称为格式控制符,它指明了以何种形式输出数据。格式控制符均以%开头,后跟其他字符。%d表示以十进制形式淑出一个整数。除了%d,printf支持更多的格式控制,例如:
- %c 输出一个字符。c是character的简写。
- %s 输出一个字符串。s是string的简写。
- %f 输出一个小数。 f是float的简写。
四、整数
- short,int,long是C语言中常见的整数类型,其中int称为整型,short称为短整型,long称为长整型
- 但是实际上C语言中并没有严格规定short,int,long的长度,只做了宽泛的限制
- short至少占用2个字节。
- int建议为一个机器字长。32位环境下机器字长为4字节,64位环境下机器字长为8字节。
- short的长度不能大于int,long的长度不能小于int。
2 <= short <= int <= long
- 这就意味着,short并不一定真的“短”,long也不一定真的“长”,他们有可能和int占用相同的字节。
二进制数、八进制数、十六进制数
- 二进制由 0 和 1 两个数字组成,使用时必须以 0b 或 0B(不区分大小写)开头
- 八进制由 0~7 八个数字组成,使用时必须以 0 开头(注意是数字 0,不是字母 o)
- 十六进制由数字 0~9、字母 A~F 或 a~f(不区分大小写)组成,使用时必须以 0x 或 0X(不区分大小写)开头
- 十六进制数字的表示用到了英文字母,有大小写之分,要在格式控制符中体现出来:
- %hx、%x 和 %lx 中的 x 小写,表明以小写字母的形式输出十六进制数
- %hX、%X 和 %lX 中的 X 大写,表明以大写字母的形式输出十六进制数
#include<stdio.h>
int main()
{
short a = 0b1010110;
int b = 02713;
long c = 0X1DAB83;
printf("a = %ho,b = %o,c = %lo \n", a, b, c); //以八进制的形式输出
printf("a = %hd,b = %d,c = %lx \n", a, b, c); //以十进制的形式输出
printf("a = %hx,b = %x,c = %lx \n", a, b, c); //以十六进制的形式输出(字母小写)
printf("a = %hX,b = %X,c = %lX \n", a, b, c); //以十六进制的形式输出(字母大写)
return 0;
}
结果:
- 从这个例子可以发现,一个数字不管以何种进制来表示,都能够以任意进制的形式输出。数字在内存中始终以二进制的形式存储,其它进制的数字在存储前都必须转换为二进制形式;同理,一个数字在输出时要进行逆向的转换,也就是从二进制转换为其他进制。
正负数
- 在数学中,数字有正负之分。在 C 语言中也是一样,short、int、long 都可以带上正负号
//负数
short a1 = -10;
short a2 = -0x2dc9; //16进制
//正数
int b1 = +10;
int b2 = +0174; //八进制
int b3 = 22910;
//负数和正数相加
long c = (-9) + (+12);
- C语言规定把内存的最高位作为符号位。用0表示正数,用1表示负数。
五、小数
- 小数分为整数部分和小数部分,由点.号分割。
- 小数可以使用printf函数输出,包括十进制形式和指数形式,他们对应的格式控制符分别是:
- 下面的代码演示了小数的表示以及输出
#include<stdio.h>
#include<stdlib.h>
int main()
{
float a = 0.302;
float b = 128.101;
double c = 123;
float d = 112.64E3;
double e = 0.7623e-2;
float f = 1.23002398;
printf("a = %e \n b = %f \n c = %lf \n d = %lE \n e = %lf \n f = %f \n", a, b, c, d, e, f);
return 0;
}
结果:
六、C语言转义字符
- 转移字符以\或者\x开头,以\开头表示后跟八进制形式的编码值,以\x开头表示后跟十六进制形式的编码值。
- 对于转义字符来说,只能使用八进制或者十六进制。
- 常用的转义字符如下:
七、C语言标识符、关键字、注释、表达式和语句
- 标识符
C语言规定,标识符只能由字母(A—Z, a—z)、数字(0~9)和下划线(_)组成,并且第一个字符必须是字母或下划线,不能是数字。
- 关键字
标准 C 语言中一共规定了 32 个关键字
- 注释
- 单行注释以//开头,直到本行末尾(不能换行)
- 多行注释以/开头,以/结尾,注释内容可以有一行或多行
- 表达式和语句
- 表达式可以看做一个计算的公式,往往由数据、变量、运算符等组成,例如 3*4+5、a=c=d 等,表达式的结果必定是一个值;
- 语句的范围更加广泛,不一定是计算,不一定有值,可以是某个操作、某个函数、选择结构、循环等
八、C语言中的运算
- 加减乘除
代码实现如下
#include<stdio.h>
int main()
{
int a = 12;
int b = 100;
float c = 8.5;
int m = a + b;
float n = b * c;
double p = a / c;
int q = b % a;
printf("m = % d,n = % f,p = % lf,q = % d \n", m, n, p, q);
return 0;
}
结果:
- 自增(++)自减(–)
- 话不多说,直接上代码
#include<stdio.h>
int main()
{
int a = 10, b = 20;
printf("a = % d,b = %d \n", a, b);
++a;
--b;
printf("a = % d,b = % d \n", a, b);
a++;
b--;
printf("a = %d,b = %d \n", a, b);
return 0;
}
结果:
- 需要重点说明的是,++ 在变量前面和后面是有区别的:
++ 在前面叫做前自增(例如 ++a)。前自增先进行自增运算,再进行其他操作。
++ 在后面叫做后自增(例如 a++)。后自增先进行其他操作,再进行自增运算。
自减(–)也一样,有前自减和后自减之分。
九、数据类型转换
数据类型转换就是将数据(变量、数值、表达式的结果等)从一种类型转换为另一种类型,在C语言中,数据类型转换有两种方式,自动类型转换和强制类型转换
- 自动类型转换
自动类型转换就是编译器默默地、隐式地、偷偷地进行的数据类型转换,这种转换不需要程序员干预,会自动发生。
- 强制类型转换
如果需要,程序员也可以自己在代码中明确地提出要进行类型转换,这称为强制类型转换。
- 强制类型转换的格式为:
(type_name) expression
type_name 为新类型名称,expression 为表达式。
(float)a; //将变量 a 转换为 float 类型
(int)(x + y); //把表达式 x+y 的结果转换为 int 整型
(float)100; //将数值 100(默认为int类型)转换为 float 类型
- 但是类型转换只是临时的,无论是自动类型转换还是强制类型转换,都只是为了本次运算而进行的临时性转换,转换的结果也会保存到临时的
内存空间,不会改变数据本来的类型或者值。