宏函数(实际叫宏函数不准确,应该叫宏定义,因为它不是函数,往下看你就会知道原因了)
MAX((a), (b)) (a) > (b)? (a):(b) ---------1
内联函数
inline int get_max(int a, int b)
{
return a>b? a;b; ---------2 等价于return MAX(a,b);
}
普通函数
int get_max(int a, int b)
{
return a>b? a;b; ---------3等价于return MAX(a,b);
}
宏函数特点
宏函数也是宏,宏只是做文本替换,发生在预编译阶段,所以2和3这2条语句都等价于MAX(a,b),不是函数,就没有出栈和入栈的时间消耗,所以执行速度快
但是注意的是宏不进行类型检查,这个是有一定风险的,但这个也是有点优势的,例如我们想比较2个long、short、float型变量,如果是普通函数,则必须另外再写几个不一样的普通函数
宏在代码里面有多份拷贝,函数只是一份拷贝,所以函数更节约内存,宏可以说只是一个简单的复制粘贴
宏只有传值,函数有传地址和值
宏太多会让代码变得很难阅读,太长会让代码变得很大
内联函数特点
inline修饰的函数不一定是内联函数,编译器判断一个函数是否为内联函数,并不仅仅inline关键字为依据,还必须满足几个必要条件,(好像现在的编译器很强大,会优化哪些并没有inline修饰的,但又是频繁被调用的简单函数)
必要条件:
1.不能使用递归
2.不能使用while、for、switch等,且语句不超过5条(反正要短小,不要复杂)
3.只能先定义后使用
内联函数有宏函数的优点,因为它是在编译阶段嵌入相应调用的地方(宏函数发生在预编译阶段),实际也是复制粘贴,所以没有函数调用的开销
各自比较与选择
普通函数就没有什么可讲的了,函数最大的好处就是消除重复代码,消除重复代码是高质量代码的保证,还能节约空间
普通函数和上面2中比较,节约空间,因为只有一份拷贝,上面2个有多份拷贝,但是上面2个少了函数调用开销
内联函数和宏函数,内联函数有类型检查,宏函数没有,所有规避了一些风险