C++笔记 第九课 函数重载分析(下)---狄泰学院

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/weixin_42187898/article/details/83302252

如果在阅读过程中发现有错误,望评论指正,希望大家一起学习,一起进步。
学习C++编译环境:Linux

第九课 函数重载分析(下)

1.重载与指针

下面的函数指针将保存哪个函数的地址?第一个
在这里插入图片描述
函数重载遇上函数指针
将重载函数名赋值给函数指针时
1.根据重载规则挑选与函数指针参数列表一致的候选者
2.严格匹配候选者的函数类型与函数指针的函数类型

9-1 函数重载VS函数指针

#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;
        
    c = p(1);   
    
    printf("c = %d\n", c);
    return 0;
}
运行结果
lkk@lkk-virtual-machine:~/c++$ g++ 9-1.cpp
lkk@lkk-virtual-machine:~/c++$ ./a.out
c = 1

注意
1.函数重载必然发生在同一个作用域中
2.编译器需要用参数列表或函数类型进行函数选择
3.无法直接通过函数名得到重载函数的入口地址
printf("%p\n", (int()(int, int))add);
printf("%p\n", (int(
)(int, int, int))add);
解释:函数指针使用,挑选函数类型来进行函数选择

2.C++和C相互调用

实际工程中C++和C代码相互调用是不可避免的
C++编译器能够兼容C语言的编译方式
C++编译器会优先使用C++编译方式
extern关键字能强制让C++编译器进行C方式的编译

9-2 C++调用C函数

main.cpp
#include <stdio.h>
#ifdef __cplusplus
extern "C" {
#endif
#include "add.h"
#ifdef __cplusplus
}
#endif
int main()
{
    int c = add(1, 2);
    
    printf("c = %d\n", c);
    
    return 0;
}
add.c
#include "add.h"
int add(int a, int b)
{
    return a + b;
}
add.h
int add(int a, int b);

在这里插入图片描述

3.问题:如何保证一段C代码只会以C的方式被编译?

解决方案:_cplusplus是C++编译器内置的标准宏定义
_cplusplus的意义:确保C代码以统一的C方式被编译成目标文件
在这里插入图片描述
课后练习:C调用C++函数
解决方案运行结果:
lkk@lkk-virtual-machine:~/c++/9-2$ g++ main.cpp add.o
lkk@lkk-virtual-machine:~/c++/9-2$ ./a.out
c = 3
lkk@lkk-virtual-machine:~/c++/9-2$ gcc main.cpp add.o
lkk@lkk-virtual-machine:~/c++/9-2$ ./a.out
c = 3

4.注意事项

C++编译器不能以C的方式编译重载函数
编译方式决定函数名被编译后的目标名
C++编译方式将函数名和参数列表编译成目标名
C编译方式只将函数名作为目标名进行编译
小结
函数重载是C++对C的一个重要升级
函数重载通过函数参数列表区分不同的同名函数
extern关键字能够实现C和C++的相互调用
编译方式决定符号表中的函数名的最终目标名
extern “C”{} 代码块中不能包含函数重载

猜你喜欢

转载自blog.csdn.net/weixin_42187898/article/details/83302252