C++小白到大白养成记 - 养成记9:函数重载的分析(下)

--事物的难度远远低于对事物的恐惧!    

    上一节对函数重载做了个大概的分析,这节我们来做个比较深一点的分析。

    1、函数重载遇上函数指针
        -将重载函数名赋值给函数指针时
            ->根据重载规则挑选与函数指针参数列表一致的候选者

            ->严格匹配候选者的函数类型与函数指针的函数类型

#include <stdio.h>
#include <string.h>

int func(int x)
{
    return x;
}

int func(int a, int b)
{
    return a + b;
}

int func(const char* s)
{
    return strlen(s);
}

typedef int(*PFUNC)(int a); //这个函数指针,指向的函数必须严格匹配返回值与参数列表


int main(int argc, char *argv[])
{
    int c = 0;

    PFUNC p = func;  //p指向的函数func,其返回值与参数列表必须严格与p指针的类型相匹配
        
    c = p(1);   
    
    printf("c = %d\n", c);

    return 0;
}
编译输出一下,很明显,匹配的是int fun(int x)这个函数:

函数重载的注意事项:
    -函数重载必须发生在同一个作用域内
    -编译器需要用参数列表函数类型进行函数选择

    -无法直接通过函数名得到重载函数的入口地址

函数重载基本已经分析完了,现在来看个题外话:实际工程中C++和C代码的相互调用
    -C++编译器能够兼容C语言的编译方式
    -C++编译器会优先使用C++编译的方式
    -extern关键字能强制让C++编译器按C方式进行编译

extern "C"
{
    //your code...
}
extern "C"是C++中的标识,在C编译器中无法识别,即编译会报错,那么如何确保一段代码只按C方式编译呢?

    -答案便是使用C++编译器内置的标准宏定义:__cplusplus  
   
通过如下方式,便可以确保C代码以统一C方式被编译成目标文件,这样不论是C++编译器还是C编译器,都会以C的方式进行编译

#ifdef __cplusplus
extern "C"
{
#endif 

//C-Style Compliation

#ifdef __cplusplus
}
#endif
注意事项:
    -C++编译器 不能以C的方式编译重载函数
    - 编译方式决定函数被编译后的 目标名
        ->C++编译方式将 函数名参数列表编译成目标名

        ->C编译方式只将函数名作为目标名进行编译

总结:
    -函数重载是C++对C的一个重要升级
    -函数重载需要在同一个作用域中
    -函数重载通过函数参数列表区分不同的同名函数
    -extern关键字能够实现C和C++的相互调用
    -编译方式决定符号表中的函数名的最终目标名

猜你喜欢

转载自blog.csdn.net/lms1008611/article/details/80561066