内存分配方案
1.未初始化的全局变量---- .bss段
2.初始化的全局变量----- 。data段
3.常量数据------- 。rodata段
4.rodata段是在多个进程中共享的
5.栈用于存储临时变量和函数参数
宏定义
1.宏定义是用宏名代替一个字符串,是简单置换,不做正确性检查
2.宏定义不需要行末加分号
3.#define命令出现在程序中函数的外面,宏名的有限范围是定义命令之后到本源文件结束
4.可以用#undef 命令终止宏定义的作用域
5.对程序中用双引号括起来的字符串内的字符,不进行置换
带参数的宏定义
带参数的宏定义与函数时的不同
1。函数调用时,先求出实参表达式的值,然后带入形参。而宏只是进行简单的字符替换
2.函数调用是程序运行时处理的,为形参分配临时的内存。宏展开是在编译前进行的,在展开时不分配内存单元,不进行值得传递处理,也没有返回值的概念
3.对函数的实参与形参都要定义类型,二者要求一致。而宏不存在类型问题,宏定义时可以是任何类型的数据
4.宏替换不占用运行时间,只占用编译时间。
条件编译
#if
#if (MAX>0)
code
#end if
如果MAX >10成立那编译器会把代码段code编译进去(是编译不是运行)
#if defined
#if defined(x)
code
#endif
只要定义了X这个宏就会编译中间的code否则直接忽略
也可以 #if !defined(x)
#ifdef
#ifdef的使用和#if defined(x)用法一致
这几个宏定义只决定相应代码段是否被编译
最后要加#endif
结构体
见链表部分
枚举
1.先定义枚举类型,在定义变量
enum DAY{
MON=1,
TUE=2,
WED,
THU
};
enum DAY day;
2.定义枚举类型的同时定义变量
enum DAY{
MON=1,
TUE=2,
WED,
THU
}day;
3.省略枚举名称,直接定义枚举变量
enum{
MON=1,
TUE=2,
WED,
THU
}day;
联合体-共用体
在联合体内,各成员使用同一段空间,联合体变量的长度等于最长成员的长度。联合体变量成员赋值,每次只能给一种值,赋予新值则冲去旧值
1.
union data{
int a ;
char ch;
double f;
};
union data a,b,c;
2.
union data{
int a ;
char ch;
double f;
}a,b,c;
3.
union {
int a ;
char ch;
double f;
}a,b,c;