c++-内联函数和函数重载和默认参数和函数指针

内联函数

C++ 内联函数是一般与类一块儿使用。若是一个函数是内联的,那么在编译时,编译器会把该函数的代码副本放置在每一个调用该函数的地方。ios

对内联函数进行任何修改,都须要从新编译函数的全部客户端,由于编译器须要从新更换一次全部的代码,不然将会继续使用旧的函数。函数

若是想把一个函数定义为内联函数,则须要在函数名前面放置关键字 inline,在调用函数以前须要对函数进行定义。若是已定义的函数多于一行,编译器会忽略 inline 限定符。spa

在类定义中的定义的函数都是内联函数,即便没有使用 inline 说明符。指针

#define _CRT_SECURE_NO_WARNINGS
#include <iostream>


using namespace std;

#define MAX(a, b) \
    ((a)>(b)?(a):(b))

int max(int a, int b)
{
    return (a > b) ? a : b;
}

inline void printAB(int a, int b);


int main(void)
{
    int a = 10;
    int b = 20;
    int c = 0;

    // MAX(a++, b++);
    
    cout <<"c = " <<c<<endl;
#if 1
    for (int i = 0; i < 1000; i++) {
        a++;
        b++;
        printAB(a++, b++);
    }
#endif
    return 0;
}

inline void printAB(int a, int b)
{
    cout << "a = " << a << ", b = " << b << endl;
}

默认参数(形参有一个默认值,有一个是默认参数,则右边的均是默认参数才行)

默认参数和占位参数在一块儿 int func(int a, int b, int =0)code

#define _CRT_SECURE_NO_WARNINGS
#include <iostream>


using namespace std;

void func(int a = 666)
{
    cout << "a = " << a << endl;
}

//求立方体体积
int get_volume(int len, int width=199, int height=10)
{
    cout << "len = " << len << endl;
    cout << "w = " << width << endl;
    cout << "h = " << height << endl;

    return len *width*height;
}


void func2(int x, int=0)//亚元
{
    cout << "x =" << x << endl;

}

int main(void)
{
    int value = 10;

    func();

    int len = 10;
    int w = 20;
    int h = 30;


    cout << "体积是" << get_volume(w,h) << endl;

    func2(199, 10);
    func2(200);

    return 0;
}

函数重载

函数占位参数 运算符重载后置++ int func(int a, int b, int ) 在函数体内部没法使用占位参数作用域

在同一个做用域内,能够声明几个功能相似的同名函数,可是这些同名函数的形式参数(指参数的个数、类型或者顺序)必须不一样。您不能仅经过返回类型的不一样来重载函数。get

  • 概念(函数名称同样 函数参数不同)
  • 函数返回值不是判断标准
  • 调用规则(按照名称、个数、类型)
  • 函数重载赶上函数默认参数,调用是二义性
  • 函数指针语法:定义函数类型 定义函数指针类型 定义函数指针变量
  • 函数重载和函数指针在一块儿
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>


using namespace std;

//函数的返回值, 函数形参列表(参数的个数,参数类型,参数顺序)
//函数重载  函数名相同, 参数列表不一样
//函数返回值并非构成函数重载的条件
int func(int a, int b) 
{
    cout << "func1" << endl;
    return 0;
}

//若是要是函数重载话,不要写默认参数,为了不调用出现函数冲突
char func(int a, int b, int)
{
    cout << "func2" << endl;
    return 0;
}

#if 1
int func(int a, char *str)
{
    cout << "func3" << endl;
    return 0;
}
#endif

void print1(int a)
{
    cout << "print 1" << endl;
    cout << "a = " << a << endl;
}

void print1(double b)
{
    cout << "print 2" << endl;
    cout << "b = " << b << endl;
}
void print1(char ch)
{
    cout << "print 3" << endl;
    cout << "ch =" << ch << endl;
}

int main(void)
{
    func(10, 20);

    func(10, "abc");

    print1(10);

    print1(19.00);

    print1(3.1f);

    print1('a');//char->int

    //print1("itcast");
    //1 若是可以严格匹配调用彻底匹配的
    //2 若是没有彻底匹配,调用隐士转换
    //3 都匹配不到,调用失败。

    return 0;
}

函数重载和函数指针

#define _CRT_SECURE_NO_WARNINGS
#include <iostream>

using namespace std;



int func(int a, int b)
{
    cout << "func(int, int)" << endl;
    return 0;
}

int func(int a, int b, int c)
{
    cout << "func(int, int,int )" << endl;
    return 0;
}

//1 . 定义一种函数类型
typedef int(MY_FUNC)(int, int);

//2 顶一个指向之中函数类型的指针类型
typedef int(*MY_FUNC_P)(int, int);

int main(void)
{
    //1.
    MY_FUNC *fp = NULL;
    fp = func;
    fp(10, 20);


    //2.
    MY_FUNC_P fp1 = NULL;

    fp1 = func;
    fp1(10, 20);

    //3. 
    int(*fp3)(int, int) = NULL;
    fp3 = func;
    fp3(10, 20);

    func(10, 20);
    func(10, 20, 30);

    fp3 = func; //fp3 ---> func(int,int)

    //实际上在给函数指针赋值的时候,是会发生函数重载匹配的
    //在调用函数指针的时候,所调用的函数就已经固定了。
    int(*fp4)(int, int, int) = NULL;
    fp4 = func; //fp4 ---> func(int,int,int)


    fp3(10, 30);//func(int,int)
    fp3(10, 20);

    fp4(10, 30, 30);

    return 0;
}
相关文章
相关标签/搜索