<b>高质量C++/C编程指南-第8章-C++函数的高级特点(4)</b>[VC/C++编程]
本文“<b>高质量C++/C编程指南-第8章-C++函数的高级特点(4)</b>[VC/C++编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
8.3 参数的缺省值
有一些参数的值在每次函数调用时都相同,书写这样的语句会令人讨厌.C++语言采取参数的缺省值使书写变得简便(在编译时,缺省值由编译器自动插入).
参数缺省值的利用法则:
l 【法则8-3-1】参数缺省值只能呈目前函数的声明中,而不能呈目前定义体中.
比方:
void Foo(int x=0, int y=0); // 精确,缺省值呈目前函数的声明中
void Foo(int x=0, int y=0) // 错误,缺省值呈目前函数的定义体中
{
…
}
为什么会这样?我想是有两个缘由:一是函数的实现(定义)本来就与参数能否有缺省值无关,所以没有必要让缺省值呈目前函数的定义体中.二是参数的缺省值大概会窜改,明显改正函数的声明比改正函数的定义要便利.
l 【法则8-3-2】假如函数有多个参数,参数只能从后向前挨个儿缺省,不然将招致函数调用语句怪模怪样.
精确的示比方下:
void Foo(int x, int y=0, int z=0);
错误的示比方下:
void Foo(int x=0, int y, int z=0);
要注意,利用参数的缺省值并没有赋予函数新的功效,仅仅是使书写变得简便一些.它大概会提高函数的易用性,但是也大概会降低函数的可理解性.所以我们只能适本地利用参数的缺省值,要避免利用不当产生负面效果.示例8-3-2中,不公道地利用参数的缺省值将招致重载函数output产生二义性.
#include <iostream.h>
void output( int x);
void output( int x, float y=0.0);
void output( int x)
{
cout << " output int " << x << endl ;
}
void output( int x, float y)
{
cout << " output int " << x << " and float " << y << endl ;
}
void main(void)
{
int x=1;
float y=0.5;
// output(x); // error! ambiguous call
output(x,y); // output int 1 and float 0.5
}
示例8-3-2 参数的缺省值将招致重载函数产生二义性
8.4 运算符重载
8.4.1 概念
在C++语言中,可以用关键字operator加上运算符来表示函数,叫做运算符重载.比方两个复数相加函数:
Complex Add(const Complex &a, const Complex &b);
可以用运算符重载来表示:
Complex operator +(const Complex &a, const Complex &b);
运算符与普通函数在调用时的差别之处是:关于普通函数,参数呈目前圆括号内;而关于运算符,参数呈目前其左、右侧.比方
Complex a, b, c;
…
c = Add(a, b); // 用普通函数
c = a + b; // 用运算符 +
假如运算符被重载为全局函数,那么只有一个参数的运算符叫做一元运算符,有两个参数的运算符叫做二元运算符.
假如运算符被重载为类的成员函数,那么一元运算符没有参数,二元运算符只有一个右侧参数,因为对象自己成了左侧参数.
从语法上讲,运算符既可以定义为全局函数,也可以定义为成员函数.文献[Murray , p44-p47]对此问题作了较多的阐述,并总结了表8-4-1的法则.
运算符
法则
全部的一元运算符
倡议重载为成员函数
= () [] ->
只能重载为成员函数
+= -= /= *= &= |= ~= %= >>= <<=
倡议重载为成员函数
全部别的运算符
倡议重载为全局函数
表8-4-1 运算符的重载法则
以上是“<b>高质量C++/C编程指南-第8章-C++函数的高级特点(4)</b>[VC/C++编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |