C++ primer explicit和virtual的使用

explicit,和构造函数一起使用.
explicit constructor指明构造函数只能显示使用,目的是为了防止不必要的隐式转化.
举个例子:
  有这样一段代码:

class A
{
   public:
     A(int);
   private:
     int num;
};

int Test(const A&) // 一个应用函数
{
   ...
}

Test(2); // 正确
过程是这样的: 编译器知道传的值是int而函数需要的是A类型,但它也同时知道调用A的构造函数将int转换成一个合适的A,所以才有上面成功的调用.换句话说,编译器处理这个调用时的情形类似下面这样:
  const A temp(2);      // 从2产生一个临时A对象
  Test(temp);     // 调用函数


如果代码写成如下样子:
class A
{
   public:
    explicit A(int);
   private:
     int num;
};

int Test(const A&) // 一个应用函数
{
   ...
}

Test(2); // 失败,不能通过隐式类型转换将int类型变量构造成成A类型变量

virtual 

在类Base中加了Virtual关键字的函数就是虚拟函数(例如函数print),于是在Base的派生类Derived中就可以通过重写虚拟函数来实现对基类虚拟函数的覆盖。当基类Base的指针point指向派生类Derived的对象时,对point的print函数的调用实际上是调用了Derived的print函数而不是Base的print函数。这是面向对象中的多态性的体现。

#include<iostream>
using namespace::std;


class Base  
{  
public:
  Base(){}  
public:  
virtual void print(){cout<<"Base"<<endl;}  
}; 
// 
class Derived:public Base  
{  
public:
  Derived(){}  
public:  
void print(){cout<<"Derived"<<endl;}  
}; 


 
int main()  
{  
Base *point=new Derived();  
Base  *point1=new Base();
point->print();  
point1->print();

虚函数只能借助于指针或者引用


评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值