内敛函数宏定义差别

Posted llguanli

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了内敛函数宏定义差别相关的知识,希望对你有一定的参考价值。

内敛函数(inline函数)

内敛函数一般规模较小,程序再调用这些成员函数时。不是真正的运行函数的调用过程(如保存返回地址等处理)。而是把函数代码嵌入程序的调用点(内敛函数在源文件里不是调用而是按原样展开),这样能够大大降低调用成员函数的时间。

类内定义的成员函数默认是内敛函数。由于在c++中一般将类定义放在头文件里。因此这些类内定义的函数也伴随着写入头文件里。函数声明一般在头文件里。而定义是不同意在头文件里的,由于他们要多次被编译。

若是内敛函数,则同意写在头文件里。

内敛函数的定义:

内联函数必须是和函数体申明在一起,才有效。像这种申明Inline Tablefunction(int I);是没有效果的,编译器仅仅是把函数作为普通的函数申明,我们必须定义函数体。

Inline tablefunction(int I) {return I*I};

内敛函数的应用:

应用一:定义类成员变量的存取函数

内联函数在C++类中,应用最广的,应该是用来定义存取函数。我们定义的类中通常会把数据成员定义成私有的或者保护的。这样,外界就不能直接读写我们类成员的数据了。对于私有或者保护成员的读写就必须使用成员接口函数来进行。假设我们把这些读写成员函数定义成内联函数的话,将会获得比較好的效率。

Class sample{

 Private:

  Int nTest;

 Public:

  Int readtest(){ return nTest;}   //读取成员变量

   Void settest(int I) {nTest=I;}    //设置成员变量

}

应用二:实现宏的效果

宏在使用时,不进行參数检查,easy出现二义性。

如实现计算x平方:

#define TABLE_MULTI(x) ((x)*(x))

若输入參数为表达式:a++; (a=4),他们本意是希望得到(a+1)*(a+1)的结果,而实际上呢?我们能够看看宏的展开结果: (a++)*(a++),假设a的值是4,我们得到的结果是5*6=30。

改为内敛函数则无此歧义,由于内敛函数是真正的函数,运行的是函数的调用。

inline int square(int x){ return x*x;};

当然,内联函数也有一定的局限性。就是函数中的运行代码不能太多了。假设,内联函数的函数体过大,一般的编译器会放弃内联方式,而採用普通的方式调用函数。

这样,内联函数就和普通函数运行效率一样了。

1、宏的特点

为什么要使用宏呢?由于函数的调用必需要将程序运行的顺序转移到函数所存放在内存中的某个地址,将函数的程序内容运行完后,再返回到转去运行该函数前的地方。这样的转移操作要求在转去运行前要保存现场并记忆运行的地址,转回后要恢复现场,并按原来保存地址继续运行。因此,函数调用要有一定的时间和空间方面的开销,于是将影响其效率。

而宏仅仅是在预处理的地方把代码展开,不需要额外的空间和时间方面的开销。所以调用一个宏比调用一个函数更有效率。 

宏也有非常多的不尽人意的地方。

  1) 宏不能訪问对象的私有成员。
  2) 宏的定义非常easy产生二意性。

如:#define TABLE_MULTI(x) ((x)*(x))

TABLE_MULTI(a++)调用它。他们本意是希望得到(a+1)*(a+1)的结果,而实际上呢?我们能够看看宏的展开结果: (a++)*(a++)。假设a的值是4,我们得到的结果是5*6=30

以下就是用我要介绍的内联函数来解决这些问题,我们能够使用内联函数来代替宏的定义。并且其实我们能够用内联函数全然代替预处理宏。



  内联函数和宏的差别在于。宏是由预处理器对宏进行替代,而内联函数是通过编译器控制来实现的。

并且内联函数是真正的函数。仅仅是在须要用到的时候。内联函数像宏一样的展开。所以取消了函数的參数压栈。降低了调用的开销。你能够象调用函数一样来调用内联函数。而不必操心会产生于处理宏的一些问题。


以上是关于内敛函数宏定义差别的主要内容,如果未能解决你的问题,请参考以下文章

C语言开发必会 宏定义宏函数

iOS宏定义介绍

c/c++宏函数的定义与使用(宏定义函数)(macro definition)

C语言宏定义

c语言宏定义有无参数的区别

当结构体遇上宏定义,以及函数指针的高级写法(结构体中能用宏定义一个函数?)