C++深度解析(19)—类中的函数重载

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/qq_22847457/article/details/96482432

1.函数重载回顾 

  • 函数重载的本质为相互独立的不同函数 
  • C++中通过函数名和函数参数确定函数调用 
  • 无法直接通过函数名得到重载函数的入口地址 
  • 函数重载必然发生在同—个作用域中 

2.类中的重载

  • 类中的成员函数可以进行重载 
    • 构造函数的重载 
    • 普通成员函数的重载 
    • 静态成员函数的重载 
  • 问题: 全局函数,普通成员函数以及静态成员函数之间是否可以构成重载? 

3.万变不离其宗 

  • 1. 重载函数的本质为多个不同的函数 
  • 2. 函数名和参数列表是唯—的标识 
  • 3. 函数重载必须发生在同一个作用域中

 
 
  1. #include<stdio.h>
  2. class Test
  3. {
  4. int i;
  5. public:
  6. Test()
  7. {
  8. printf( "Test::Test()\n");
  9. this->i = 0;
  10. }
  11. Test( int i)
  12. {
  13. printf( "Test::Test(int i)\n");
  14. this->i = i;
  15. }
  16. Test( const Test &obj)
  17. {
  18. printf( "Test(const Test &obj)\n");
  19. this->i = obj.i;
  20. }
  21. static void func()
  22. {
  23. printf( "void Test::func()\n");
  24. }
  25. void func(int i)
  26. {
  27. printf( "void Test::func(int i),i = %d\n", i);
  28. }
  29. int getI()
  30. {
  31. return i;
  32. }
  33. };
  34. void func()
  35. {
  36. printf( "void func()\n");
  37. }
  38. void func(int i)
  39. {
  40. printf( "void func(int i),i = %d\n", i);
  41. }
  42. int main()
  43. {
  44. func(); //全局函数的重载
  45. func( 1); //通过参数列表
  46. Test t; //成员函数的重载
  47. Test t1(1);
  48. Test t2(t1);
  49. func(); //全局函数和静态成员函数之间的重载,注意作用域
  50. Test::func();
  51. func( 2); //全局函数与普通成员函数之间的重载,注意作用域
  52. t1.func( 2);
  53. t1.func();
  54. getchar();
  55. return 0;
  56. }
  • 运行结果

4.重载的意义

  • 通过函数名对函数功能进行提示
  • 通过参数列表对函数用法进行提示
  • 扩展系统中已经存在的函数功能

 
 
  1. #include <stdio.h>
  2. #include <string.h>
  3. char *strcpy(char *buf, const char * str, unsigned int n)
  4. { //重构原有函数
  5. return strncpy(buf, str, n);
  6. }
  7. int main()
  8. {
  9. const char *s = "Hello World";
  10. char buf[ 16] = { 0 };
  11. strcpy(buf, s, sizeof(buf) - 1);
  12. printf( "%s\n", buf);
  13. getchar();
  14. return 0;
  15. }
  • 打印结果为所给字符串。

6.小结

  • 类的成员函数之间可以进行重载
  • 重载必须发生在同一个作用域中
  • 全局函数和成员函数不能构成重载关系(不在同一个作用域中)
  • 重载的意义在于扩展已经存在的功能

【C++】函数重载分析

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接: https://blog.csdn.net/qq_40416052/article/details/82354151

  函数重载:您可以在相同的范围内对同一个函数名有多个定义。函数的定义必须根据参数列表中的参数和/或参数的数量而有所不同。您不能重载仅由返回类型不同的函数声明。

一、函数重载分析

(1)特点

1.同一个函数名定义不同的函数。
2.当函数名和不同的参数搭配时函数的定义不同

example :


 
 
  1. #include <stdio.h>
  2. #include <string.h>
  3. #include <iostream>
  4. int func(int x)
  5. {
  6. return x;
  7. }
  8. int func(int a, int b)
  9. {
  10. return a + b;
  11. }
  12. int func(const char* s)
  13. {
  14. return strlen(s);
  15. }
  16. int main(int argc, char *argv[])
  17. {
  18. printf( "%d\n", func( 3));
  19. printf( "%d\n", func( 4, 5));
  20. printf( "%d\n", func( "D.T.Software"));
  21. system( "pause");
  22. return 0;
  23. }

编译运行:

可见,函数名相同,参数类型和参数个数不同,系统会调用不同的函数。

(2)函数重载至少满足下面的一个条件

1.参数个数不同
2.参数类型不同
3.参数顺序不同

 example :


 
 
  1. int func(int a, const char* s)
  2. {
  3. return a;
  4. }
  5. int func(const char* s, int a)
  6. {
  7. return strlen(s);
  8. }

上面的两个函数也是重载函数。

(3)当函数默认参数遇上函数重载会发生什么?

example:


 
 
  1. #include <stdio.h>
  2. int func(int a, int b, int c = 0)
  3. {
  4. return a * b * c;
  5. }
  6. int func(int a, int b)
  7. {
  8. return a + b;
  9. }
  10. int main( int argc, char *argv[])
  11. {
  12. int c = func(1, 2);
  13. return 0;
  14. }

编译运行:

可见,编译器不知道调用哪个函数,从而产生二义性。

 (4)函数重载的注意事项

1.重载函数在本质上是相互独立的不同函数
2.重载函数的函数类型不同
3.函数返回值不能作为函数重载的依据

note;函数重载由函数名和参数列表决定的。

example:


 
 
  1. #include <stdio.h>
  2. #include <iostream>
  3. int add( int a, int b) // int( int, int)
  4. {
  5. return a + b;
  6. }
  7. int add( int a, int b, int c) // int( int, int, int)
  8. {
  9. return a + b + c;
  10. }
  11. int main()
  12. {
  13. printf( "%p\n", ( int(*)( int, int))add);
  14. printf( "%p\n", ( int(*)( int, int, int))add);
  15. system( "pause");
  16. return 0;
  17. }

编译运行:

两个重载函数打印的地址不一样,说明两个函数的编译入口不同。

二、重载与指针

(1)函数重载遇上函数指针

将重载函数名赋值给函数指针时:

1.根据重载规则挑选与函数指针列表一致的候选者 
2.严格匹配候选者的函数与函数指针的函数类型 

Test:

下面的函数指针将保存哪个函数的地址?


 
 
  1. #include <stdio.h>
  2. #include <string.h>
  3. #include <iostream>
  4. int func(int x)
  5. {
  6. return x;
  7. }
  8. int func(int a, int b)
  9. {
  10. return a + b;
  11. }
  12. int func(const char* s)
  13. {
  14. return strlen(s);
  15. }
  16. typedef int(*PFUNC)(int a);
  17. int main(int argc, char *argv[])
  18. {
  19. int c = 0;
  20. PFUNC p = func;
  21. c = p( 1);
  22. printf( "c = %d\n", c);
  23. system( "pause");
  24. return 0;
  25. }

编译运行:

说明调用的是函数:

int func(int x)
{
    return x;
}

因为typedef int(*PFUNC)(int a); 的参数类型是int ,与之匹配。

(2)注意:

1.函数重载必然发生在同一个作用域中
2.编译器需要用参数列表或函数类型进行函数选择
3.无法直接通过函数名得到重载函数的入口地址

Example:


 
 
  1. #include <stdio.h>
  2. #include <iostream>
  3. int add(int a, int b)
  4. {
  5. return a + b;
  6. }
  7. int add(int a, int b, int c)
  8. {
  9. return a + b + c;
  10. }
  11. int main(int argc, char *argv[])
  12. {
  13. printf( "%p\n", add);
  14. printf( "%p\n", add);
  15. system( "pause");
  16. return 0;
  17. }

编译运行:

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

我们将函数改成函数指针:


 
 
  1. #include <stdio.h>
  2. #include <iostream>
  3. int add(int a, int b)
  4. {
  5. return a + b;
  6. }
  7. int add(int a, int b, int c)
  8. {
  9. return a + b + c;
  10. }
  11. int main(int argc, char *argv[])
  12. {
  13. printf( "%p\n", ( int(*)( int, int))add);
  14. printf( "%p\n", ( int(*)( int, int, int))add);
  15. system( "pause");
  16. return 0;
  17. }

 编译运行,成功。

声明:

      本文为听课笔记,课程为:唐佐林老师嵌入式c++语言课程

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值