C++拾遗--函数重载

C++拾遗--函数重载

前言

函数重载似乎并不难,但仍有一些问题值得注意。下面从几个关键词入手:

正文

1.作用域

关于作用域,需要指出几点事实

  1. 用大括号{}括起来的区域处于同一作用域,常见的有函数体、for、if语句等。
  2. 同一作用域内不可出现同名的变量,若是函数同名,那就是函数重载问题。不同作用域内同名与否,没影响。
  3. 所有的函数之外的区域就是全局作用域。

首先需要指出,同一作用域中的函数才会出现重载问题。不同作用域中的函数即使是同名,且参数类型和返回值类型一致,也是两个不同的函数。

2.隐藏

当作用域存在嵌套关系时,隐藏现象会出现。

#include <iostream>
using namespace std;
//位于全局作用域的var
int var = 0;
void print(void)
{
	cout << "全局print" << endl;
}
int main()
{
	//位于局部作用域的g_var会隐藏位于全局作用域的g_var
	int var = 1;
	//局部print同样会隐藏全局print
	auto print = [](void){
		cout << "局部print" << endl;
	};
	//以下调用全为局部的
	cout << "var = " << var << endl;
	print();
	//调用全局的
	cout << "::var = " << ::var << endl;
	::print();
	cin.get();
	return 0;
}

运行

由于main函数体嵌套在全局作用域的内部,所以当出现同名对象时,会发生隐藏现象。若要调用全局的对象,需使用全局运算符::。

需要进一步指出,隐藏只是现象,本质是对象名字查找规则。C++的名字查找规则是这样的,从名字出现处到名字所处的作用域的起始处,这一段进行查找。找到即不再查找,找不到就跳到上一层作用域继续查找。

本示例代码中,可以在main函数体内找到var和print,所以调用的就是局部的。

隐藏现象表明,不同作用域的同名函数,不是重载关系。

3.const和重载

const和重载的联系是,只能通过底层const区分重载。

#include <iostream>
using namespace std;
void print(const char *str)
{
	cout << "void print(const char *str) call" << endl;
	cout << str;
}
void print(char *str)
{
	cout << "void print(char *str) call" << endl;
	cout << str;
}
int main()
{
	char str[] = "David";
	print("zhangxiang");
	cout << endl;
	print(str);
	cin.get();
	return 0;
}

运行

若把void print(const char *str)改为void print(char *const str),编译后提示错误:

error C2084: function ‘void print(char *const )‘ already has a body,也就是说顶层const无法区分重载。

本专栏目录

所有内容的目录

时间: 2024-08-05 20:03:53

C++拾遗--函数重载的相关文章

javascript 函数重载 overloading

函数重载 https://en.wikipedia.org/wiki/Function_overloading In some programming languages, function overloading or method overloading is the ability to create multiple methods of the same name with different implementations. Calls to an overloaded functi

day4 函数重载

函数的重载 1.函数重载的定义:在同一个类中,有一个以上的同名函数,只要函数的参数列表或参数类型不一样即可,与返回值无关, 这些统称为方法的重载. 2.函数的重载存在的原因:为了增强方法的阅读性,优化了程序设计. 案例1:九九乘法表 1 private static void print99() { 2 for(int i = 1 ; i<= 9 ; i ++){ 3 for(int j = 1 ; j<=i ; j++){ 4 System.out.print(i+"*"

c++中的函数重载

c++中的函数重载 什么是函数重载 重载函数是函数的一种特殊情况,为方便使用,C++允许在同一范围中声明几个功能类似的同名函数,但是这些同名函数的形式参数(指参数的个数.类型或者顺序)必须不同,这组函数被称为重载函数. 函数重载的作用 重载函数常用来实现功能类似而所处理的数据类型不同的问题,能减少函数名的数量,提高程序的可读性. 重载函数的构成说明 定义一个类,添加一系列函数名相同的函数,但参数形式各有不同,测试一下能否构成重载. #include <iostream> using names

C++函数重载实现的原理以及为什么在C++中调用C语言编译的函数时要加上extern &quot;C&quot;声明

C++相对于C语言而言支持函数重载是其极大的一个特点,相信在使用C语言的时候大家如果要写一个实现两个整型数据相加的函数还要写一个浮点型数据相加的函数,那么这两个函数的名字绝对不可以一样,这样无疑在我们使用这个函数的时候增加了复杂性,但是在C++中我们却可以很好的解决这个问题,因为在C++中函数是支持重载的也就是说两个函数的函数名可以一样,这样并不会出现函数名重定义的问题,但是我们在使用的时候也要遵守一些规定,这些规定我们会在接下来的讨论中提到,下面我们就来分析在C++中函数是如何实现函数的重载的

C++ 函数重载与函数匹配

<C++ Primer>笔记,整理关于函数重载与函数匹配的笔记. 函数重载 void func(int a); //原函数 void func(double a); //正确:形参类型不同 void func(int a, int b); // 正确:形参个数不同 int func(int a); //错误:只有返回类型不同 typedef int int32; void func(int32 a); //与原函数等价:形参类型相同 void func(const int a); //与原函数

0607pm克隆&amp;引用类&amp;加载类&amp;面向对象串讲&amp;函数重载

克隆class Ren{ public $name; public $sex; function __construct($n,$s) { $this->name=$n; $this->sex=$s; } function __clone()//改变克隆的对象内容 { $this->name="李思思";//this代表复本对象 $that->name="李思思";//that代表原本的,后来废弃了 }}$r=new Ren("张丹

函数重载、覆盖、多态

#include <iostream> using namespace std; /* *对于纯虚函数可以实现也可以不实现,但派生类一定要覆盖基类的纯虚函数.否则派生类仍然是抽象类 * *如果派生类覆盖基类的虚函数,则基类的指针或引用实际指向子类对象,那么通过该指针或引用调用虚函数时,将调用子类的虚函数;如果不是虚函数,则调用父类的函数. * */ class PEOPLE { public: int age; //派生类必须实现抽象类的纯虚函数,否则派生类仍然是抽象类 virtual voi

为什么C++支持函数重载

对于C++语言作为一种欲与C兼容的语言,C++语言保留了一部分过程式语言和特点,foo_int_int这样的名字包含了函数名.函数参数数量及类型信息,C++语言就是靠这种机制来实现函数重载的. 假设某个函数的原型为: // 模块A头文件 moduleA.h #ifndef MODULE_A_H #define MODULE_A_H int foo( int x, int y ); #endif 该函数被C编译器编译后在符号库中的名字为_foo,而C++编译器则会产生像_foo_int_int之类

C++文件头,命名空间,new和delete,内联函数,引用,函数重载,构造函数和析构函数,深拷贝和浅拷贝,explict,this指针

 目  录 1       开始学习C++.............................................................................................................. 4 1.1       C++的头文件.................................................................................................