简单不先于复杂,而是在复杂之后。
目录
常见关键字
变量的命名
关键字auto
?关键字typedef?
?关键字static
修饰局部变量
?修饰全局变量
?修饰函数
register寄存器
define定义常量和宏?
?
?
常见关键字
?auto break case char const continue default do double else enum extern float for goto if int long register return short signed sizeof static struct switch typedef union unsigned void volatile while?
这些为常见的关键字,是C语言内置的,不能自己创建。
变量的命名
1.要有意义,比如 int age, float salary;
2.名字必须是字母、数字、下划线组成,不能有特殊字符,同时不能以数字开头。
3.变量名不能是关键字
关键字auto
int main()
{
auto int a = 10;
//a变量进入作用域自动创建,出作用域自动销毁,为自动变量
//几乎所有局部变量都是 auto 类型的,所以 auto 可以忽略
return 0;
}
?关键字typedef?
typedef 顾名思义是类型定义,这里应该理解成类型重命名。
类型重命名可以把复杂的类型简化,重新起个新名字。
typedef unsigned int = unit;
int main()
{
unsigned int num = 0;
unit num2 = 1;
return 0;
}
?关键字static
在C语言中,static 是用来修饰变量和函数的。
1. 修饰局部变量 - 称为静态局部变量
2. 修饰全局变量 - 称为静态全局变量
3. 修饰函数 - 称为静态函数
修饰局部变量
有这样一段代码可以试着自己计算一下打印结果:
void test()
{
int a = 1;
a++;
printf("%d", a);
}
int main()
{
int i = 0;
while (i < 10)
{
test();
i++;
}
return 0;
}
?
?结果是10个2,因为while循环要循环10次,每次进入test函数时都会把++后的变量a也就是2打印出来,而a是局部变量,生命周期是进入作用域被创建,出作用域销毁,所以10次循环都打印2。
在前面加入static关键字后,打印结果变为2~11.
因为static修饰局部变量时,局部变量出了作用域不销毁
在本质上,static修饰局部变量时,改变了局部变量的存储位置
?上图是一整块内存,分为栈区、堆区和静态区。局部变量都在栈区里,栈区里的数据进入作用域被创建,出作用域销毁。而static将局部变量的存储位置改为了静态区,影响了局部变量的生命周期,和程序的生命周期一样长,因为static修饰的那行代码没有相对应的汇编代码,每次循环变量不被销毁而是沿用上一次循环的数据,所以会打印出2~11的结果。
介绍一下void用法:?
void test()
{
//执行任务
printf("Hello world\n");//不需要任何的返回
}
int main()
{
return 0;
}
?修饰全局变量
extern关键字可以声明外部符号。
声明之后其他.c文件的全局变量就可以在主函数中使用了
全局变量具有外部链接属性,编译+链接才可以得到可执行程序
?变量前加上static后,程序会报错。
当static修饰全局变量时,全局变量的外部链接属性会变成内部链接属性。
其他.c文件就不能使用这个全局变量了,我们在使用的时候就感觉作用域变小了
?修饰函数
修饰函数和修饰全局变量的情况很像:
?
register寄存器
?CPU处理的时候最早期从内存中拿取并计算,随着技术进步,CPU的设计使计算速度非常快,硬件读写速度不是很快,跟不上CPU的计算速度,就有了寄存器和高速缓存,计算时CPU的数据从寄存器拿取,到高速缓存中,再将内存中的数据运输高速缓存中的数据运输到寄存器中,保证大部分的数据在寄存器中,整体的CPU运算速度和计算机性能都会得到提升。
define定义常量和宏?
?之前的文章有说过define定义标识符常量:
#define NUM 100
#include<stdio.h>
int main()
{
printf("%d\n", NUM);
int n = NUM;
printf("%d\n", n);
int arr[NUM] = { 0 };
//打印结果:100
// 100
return 0;
}
ADD - 宏名
(x,y)- 宏的参数,参数是无类型的
( (x)+(y) )- 宏体?
宏是完成替换的?
?
?
|