C++中的重载丶重写丶重定义丶重定向的区别

 

C++中的重载丶重写丶重定义丶重定向的区别

分类: C、C++丶C#语言基础   404人阅读  评论(0)  收藏  举报

先看重载:

重载指的是函数的重载,又有成员函数和一般函数的重载,两者没什么区别,只是地方不一样而已

函数重载表示函数名相同,但是参数不同,函数重载在C语言里面是没有的,只限定在C++如下所示:

double  max(double x,double y),

int  max(int  x,int y);

这两个函数就是重载的范例,那么调用的时候编译器是如何确定调用哪一个勒?书本上一般说程序会根据参数类型识别调用哪一个,其实那是忽悠人的

实际上在编译期间,编译器就已经把函数名字改变了,多加了一些后缀而已(当然说自动识别也不为过)

比如上面两个程序分别编译为 max_double_double 和 max_int_int 当然这里我只是表示一下,实际上不是这样,如果要想看看名字,可以通过命令行定位到这个程序,百度上有教程,我就不累述了!


再看重写:

函数重写是发生在基类和派生类中的,基类和派生类函数名字必须相同,而且基类函数必须有virtual修饰符,结果是派生类函数覆盖了基类函数,这在C++面向基于对象的编程中

已经非常熟悉了,多态就这样出来了,如下:

Base *p =  new Child;

p-> display();

如果派生类重写了display函数  在这里就调用派生类的,否则调用基类的!


然后重定义

这个分两种情况,也是发生在基类和派生类之间

第一种:基类函数不含有vistual修饰符,在派生类中有一个与基类函数同名并且同参数的函数,这个时候基类函数在派生类中被屏蔽了,这种情况叫做一种重定义!

第二种:如果派生类的函数和基类的函数同名,但是参数不同,此时,不管有无virtual,基类的函数被隐藏。

我来解释下第二种情况,有的人可能会说,我想的就是那样啊,在派生类中写一个与基类函数名字相同,但是参数不同的函数,与继承而来的基类函数构成重载!

相信很多新手会有这种想法(我当初也是),C++ primer上面对这个问题说了,如果是想重载从基类继承而来的函数,必须手动的从基类复制该函数声明到派生类中,至于什么原因,我想又跟编译器底层有关,这就不去深究了!


最后重定向

其实这个重定向跟函数扯不上关系了,只是跟前面几个概念比较相似,他是在IO流处理的时候被提到的。

在C语言中我们知道 一个FILE指针关联到一个文件之后,重定向只需要一个freopen函数即可重新定位一个新的文件,这叫C语言的重定向

C++中,对流重定向有两个重载函数:
streambuf* rdbuf () const;
streambuf* rdbuf (streambuf*)

如下:

streambuf *backup;
ifstream fin;
fin.open("data.in");
backup = cin.rdbuf(); // back up cin's streambuf
cin.rdbuf(fin.rdbuf()); // assign file's streambuf to cin
// ... cin will read from file
cin.rdbuf(backup); // restore cin's original streambuf


注意最后我们使用了cin.rdbuf(backup)把cin又重定向回了控制台!


都快6点了,结束了一夜的学习,该睡觉了,头有点懵了,拖着疲惫的身体写出来,有些概念没写好请体谅!


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值