C++函数重载完全攻略(无师自通)
有时候需要创建两个或多个执行相同操作的函数,但使用不同的形参集或不同数据类型的形参。
例如,有一个使用 double 形参的 square 函数。但是我们还需要一个 square 函数,该函数专门用于整数,并接收一个 int 作为其实参。这两个函数都会做同样的事情:返回其实参的平方值,唯一的区别是参与操作的数据类型。如果在同一程序中使用这两个函数,则可以为每个函数分配唯一的名称。例如,对于使用 int 的函数可以命名为 squarelnt,对于使用 double 的函数可以命名为 squareDouble。
但是,C++ 允许函数重载,这意味着可以为多个函数分配相同的名称,只要它们的形参列表不同即可。下面的程序演示了该功能:
#include <iostream> #include <iomanip> using namespace std; // Function prototypes int square(int); double square(double); int main() { int userInt; double userReal; // Get an int and a double cout << "Enter an integer and a floating-point value: "; cin >> userInt >> userReal; // Display their squares cout << "Here are their squares:"; cout << fixed << showpoint << setprecision(2); cout << square(userInt) << " and " << square(userReal) << endl; return 0; } int square (int number) { return number * number; } double square(double number) { return number * number; }
程序输出结果:
Enter an integer and a floating-point value: 12 4.2
Here are their squares: 144 and 17.64
以下是程序中使用的 square 函数的函数头:
int square(int number)
double square(double number)
在 C++ 中,每个函数都有一个签名。函数签名是函数的名称和函数形参的数据类型顺序。因此,上面程序中的 square 函数具有以下签名:
square(int)
square(double)
当调用重载函数时,C++ 将使用函数签名将其与具有相同名称的其他函数区分开来。在上面程序中,当 int 实参被传递给 square 时,调用具有 int 形参的函数版本。同样,当 double 实参被传递给 square 时,将调用带有 double 形参的版本。
请注意,函数的返回值不是签名的一部分。以下函数无法在同一程序中使用,因为它们的形参列表并无差异。
int square(int number) { return number * number; } double square (int number) //错误!形参列表必须不同 { return number * number; }
当有类似函数使用不同数量的形参时,重载也很方便。例如,假设有一个程序包含的函数可以返回整数和。其中一个函数返回 2 个整数的和,另一个返回 3 个整数的和,还有一个返回 4 个整数的和。以下是它们的函数头:
int sum(int num1, int num2)
int sum(int num1, int num2, int num3)
int sum(int num1, int num2, int num3, int num4)
由于每个函数的形参数量不同,所以它们可以在同一个程序中使用。下面程序使用了 2 个函数,每一个都被命名为 CalcWeeklyPay,以确定员工的每周总收入。一个版本的函数使用一个 int 和一个 double 形参,而另一个版本则仅使用一个 double 形参。
#include <iostream> #include <iomanip> using namespace std; //Function prototypes char getChoice (); double calcWeeklyPay(int, double); double calcWeeklyPay(double); int main() { char selection; // Menu selection int worked; // Weekly hours worked double rate, // Hourly pay rate yearly; // Annual salary // Set numeric output formatting cout << fixed << showpoint << setprecision(2); //Display the menu and get a selection cout << "Do you want to calculate the weekly pay of\n"; cout << "(H) an hourly-wage employee, or \n"; cout << "(S) a salaried employee? "; selection = getChoice (); // Process the menu selection switch (selection) { //Hourly employee case 'H': case 'h': cout << "How many hours were worked? "; cin >> worked; cout << "What is the hourly pay rate? "; cin >> rate; cout << "The gross weekly pay is $"; cout << calcWeeklyPay(worked, rate) << endl; break; //Salaried employee case 'S' : case 's' : cout << "What is the annual salary? "; cin >> yearly; cout << "The gross weekly pay is $"; cout << calcWeeklyPay(yearly) << endl; } return 0; } char getChoice() { char letter; // Holds user1s letter choice // Get the user's choice cin >> letter; // Validate the choice while (letter != 'H' && letter != 'h' && letter != 'S' && letter != 's') { cout << "Enter H or S:"; cin >> letter; } // Return the choice return letter; } double calcWeeklyPay(int hours, double payRate) { return hours * payRate; } double calcWeeklyPay(double annSalary) { return annSalary / 52.0; }
程序输出结果:
Do you want to calculate the weekly pay of
(H) an hourly-wage employee, or
(S) a salaried employee? H
How many hours were worked? 40
What is the hourly pay rate? 18.50
The gross weekly pay is $740.00