文章目录
C语言
static作用
- 限制作用域
- 对于全局变量或函数:
- static修饰的全局变量或函数,仅在当前文件内可用,其他文件不能引用。
- 对于局部变量:
- static修饰的局部变量只能在本函数中使用。
- 对于全局变量或函数:
- 延长生命周期
- static修饰的变量生命周期为整个程序。
- 存放位置
- static修饰的变量存放在静态区。
- 初始化
- static变量未赋初值时初值为0,且只初始化一次。
一、const的作用
- 修饰变量
- 规则:在定义变量时需要赋初值,而一旦定义完成后,就不能再对该变量的值进行修改了。
- 修饰指针
- 当写成
char *const a
这种形式时:- 特点:指针的指向不可修改,但是指针所指向的的内容是可以修改的。
- 当写成
char const *a
这种形式时:- 特点:指针所指向的内容不可以修改,然而指针的指向是可以改变的。
- 当写成
const char *const a
这种形式时:- 特点:指针所指向的内容以及指针自身的指向都不可以进行修改。
- 当写成
二、Typedef和Define的区别
- 原理不同:
- define:是预处理指令,在预处理时进行简单的字符串替换,不进行类型检查。
- typedef:是关键字,在编译时处理,具有类型检查功能。
- 功能不同:
- define:不仅可以为类型取别名,还可以定义常量、变量、编译开关等。
- typedef:主要用于定义类型的别名,增加代码的可读性和类型安全性。
- 作用域不同:
- define:没有作用域的限制,只要之前预定义过的宏,在以后的程序中都可以使用。
- typedef:有自己的作用域,不会影响到其他作用域的定义。
- 对指针的操作不同:
- define:定义的宏在处理指针时需要进行特殊的处理,否则可能会导致错误。
- typedef:定义的类型别名在处理指针时更加方便和安全。
- 内存占用不同:
- define:定义的宏在预处理阶段进行文本替换,可能会产生额外的代码和内存占用。
- typedef:定义的类型别名不会产生额外的内存占用,只是为已有类型赋予新的名称。
比较项目 | #define | typedef |
---|---|---|
原理 | 预处理指令,预处理时进行简单字符串替换,不做类型检查 | 关键字,在编译时处理,具备类型检查功能 |
功能 | 可为类型取别名,还能定义常量、变量、编译开关等 | 主要用于定义类型别名,提升代码可读性与类型安全性 |
作用域 | 无作用域限制,预定义过的宏后续程序均可使用 | 有自身作用域,不影响其他作用域的定义 |
对指针操作 | 处理指针时需特殊处理,否则易出错 | 处理指针时更方便、安全 |
内存占用 | 预处理阶段文本替换,可能产生额外代码和内存占用 | 不会产生额外内存占用,只是给已有类型赋新名 |
三、define 和 枚举的区别
定义方式不同
#define
宏常量是在预编译阶段进行简单替换- 枚举常量则是在编译的时候确定其值
五、定义常量数量的区别
-
枚举可以一次定义大量相关的常量
-
而
#define
宏一次只能定义一个,若要定义多个互不相关的宏常量,就需要多次使用#define
语句分别定义
数据类型特性差异
-
枚举是一种用户自定义的数据类型,它为一组相关的整数常量赋予了有意义的名称。枚举里成员系统会自动赋初值,第一个成员为
0
,依次类推;如果程序员想赋值的,假设第一个成员赋值为1
,那么第二个成员系统会赋值为2
,依次类推 -
#define
仅仅是简单的文本替换,不存在像枚举这样的类型及赋值规则等数据类型相关特性。
对比项 | #define 宏常量 |
枚举常量 |
---|---|---|
定义方式 | 预编译阶段简单文本替换 | 编译时确定值,是用户自定义数据类型 |
调试能力 | 无法调试,预编译替换后原符号形式不存在,无法在调试时查看其状态 | 可以调试,有类型信息,调试时能看到值及对应枚举成员情况 |
定义常量数量 | 一次只能定义一个,定义多个需多次使用#define 语句 |
可一次定义大量相关常量 |
数据类型特性 | 仅是简单文本替换,无特定类型及赋值规则 | 有数据类型,成员默认从0开始自动赋值,程序员可指定首个成员值,后续成员依次递增 |
四、宏常量和枚举常量在C语言中各自的优缺点是什么
宏常量
-
优点:
- 效率高:在预处理阶段进行简单替换,在代码执行过程中没有额外的开销用于存储常量,一定程度上提升运行效率。
- 灵活性好:可以用于定义各种类型的常量,包括数值、字符串等。
- 方便条件编译:在处理不同平台或不同配置的代码时,宏常量可以作为条件编译的标志。
-
缺点:
- 无类型检查:只是简单的文本替换,编译器不会检查类型。例如把一个指针和宏定义的常量相加,编译器不会发现这种类型错误&