本节课讲解的主要是预处理器,编译和连接的异同。
#define有两个功能:一个是定义常量,一个是作为宏。
//定义常量
#define w 40
#define h 80
#define pere 2*(w+h)
//宏
#define MAX(a,b) (a>b?a:b)
MAX(10,40)//预处理替换为(10>40?10:40)
//int max = (fib(100) > fract(4000)) ? fib(100) : fract(4000);展开替换后的结果,编译器不会保留中间结果,函数被调用了两次,尤其是大规模的函数会导致性能下降
int max = MAX(fib(100, fract(4000)));
//int larger = ((m++) > (n++)) ? (m++) : (n++);//一共自增了3次
int larger = MAX(m++, n++);//最终会对大的两次自增,小的一次自增
注意:
1.这种宏定义市运行速度比函数快,而且不需要管参数的类型,例如:
MAX(40.2,"Hello");//预处理阶段没问题,但是编译阶段会报错。
2.在预处理阶段进行的都只是文本替换,结果作为数据传到下一阶段,预处理阶段并不进行类型检查,文本替换产生的问题会在之后的编译阶段进行识别。
3.为了避免define在预处理时不进行类型检查的缺点,应用static const定义全局变量。
//最好将重复代码写成函数或者是小段的宏,便于替换。
#define NthElemAddr(base, elemSize, index) ((char*)base + index * elemSize)
void* VectorNth(vector *v, int position)
{
assert(position > 0)
assert(position < v->logLength)
return NthElemAddr(Vector->