高质量C++/C编程指南-第6章-函数计划(2)[VC/C++编程]
本文“高质量C++/C编程指南-第6章-函数计划(2)[VC/C++编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
由于c是char范例,取值范围是[-128,127],假如宏EOF的值在char的取值范围之外,那么if语句将老是失利,这种“危险”人们普通那边料得到!招致本例错误的责任并不在用户,是函数getchar误导了利用者.
l 【法则6-2-3】不要将正常值和错误标志混在一同返回.正常值用输出参数得到,而错误标志用return语句返回.
回想上例,C尺度库函数的计划者为什么要将getchar声明为令人含糊的int范例呢?他会那么傻吗?
在正常情形下,getchar的确返回单个字符.但假如getchar碰到文件完毕标志或发生读错误,它必须返回一个标志EOF.为了辨别于正常的字符,只好将EOF定义为负数(普通为负1).因此函数getchar就成了int范例.
我们在实际工作中,常常会碰到上述令人为难的问题.为了避免呈现曲解,我们应当将正常值和错误标志脱离.即:正常值用输出参数得到,而错误标志用return语句返回.
函数getchar可以改写成 BOOL GetChar(char *c);
固然gechar比GetChar机动,比方 putchar(getchar()); 但是假如getchar用错了,它的机动性又有什么用呢?
2 【倡议6-2-1】有时刻函数本来不需求返回值,但为了增添机动性如支持链式表达,可以附加返回值.
比方字符串拷贝函数strcpy的原型:
char *strcpy(char *strDest,const char *strSrc);
strcpy函数将strSrc拷贝至输出参数strDest中,同时函数的返回值又是strDest.这样做并非画蛇添足,可以得到以下机动性:
char str[20];
int length = strlen( strcpy(str, “Hello World”) );
2 【倡议6-2-2】假如函数的返回值是一个对象,有些场所用“引用传送”替换“值传送”可以提高效率.而有些场所只能用“值传送”而不能用“引用传送”,不然会出错.
比方:
class String
{…
// 赋值函数
String & operate=(const String &other);
// 相加函数,假如没有friend修饰则只许有一个右侧参数
friend String operate+( const String &s1, const String &s2);
private:
char *m_data;
}
String的赋值函数operate = 的实现以下:
String & String::operate=(const String &other)
{
if (this == &other)
return *this;
delete m_data;
m_data = new char[strlen(other.data)+1];
strcpy(m_data, other.data);
return *this; // 返回的是 *this的引用,无需拷贝历程
}
关于赋值函数,该当用“引用传送”的方法返回String对象.假如用“值传送”的方法,固然功效仍旧精确,但由于return语句要把 *this拷贝到保存返回值的外部存储单元之中,增添了不必要的开销,降低了赋值函数的效率.比方:
String a,b,c;
…
a = b; // 假如用“值传送”,将产生一次 *this 拷贝
a = b = c; // 假如用“值传送”,将产生两次 *this 拷贝
String的相加函数operate + 的实现以下:
String operate+(const String &s1, const String &s2)
{
String temp;
delete temp.data; // temp.data是仅含‘\0’的字符串
temp.data = new char[strlen(s1.data) + strlen(s2.data) +1];
strcpy(temp.data, s1.data);
strcat(temp.data, s2.data);
return temp;
}
以上是“高质量C++/C编程指南-第6章-函数计划(2)[VC/C++编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |