C++虚函数和多态

虚函数和虚函数表

1.用virtual修饰的成员函数叫虚函数

2.空的类或者结构体占用1个字节,若只有虚函数,则占4个字节(32位)

3.虚函数表:一个指针存储所有虚函数的首地址

#include <iostream>
using namespace std;
class A
{
public:
protected:
};
class B
{
public:
	virtual void print();
protected:
};
class C
{
public:
	int num;
protected:
};
void B::print()
{
	cout << "虚函数" << endl;
}
int main()
{
	cout << sizeof(A) << endl;//1
	cout << sizeof(B) << endl;//4
	cout << sizeof(C) << endl;//4
	return 0;
}

多态

注:无virtual看指针,有virtual看赋值对象

1.定义:同一种行为(调用)导致的不同的结果

2.父类必须存在虚函数

3.子类必须采用public继承

4.子类存在同名函数

5.必须存在指针的引用

#include <iostream>
using namespace std;
class A
{
public:
	void print1()
	{
		cout << "无virtual的父类函数" << endl;
	}
	virtual void print2()
	{
		cout << "有virtual的父类函数" << endl;
	}
protected:
};
class B:public A
{
public:
	void print1()
	{
		cout << "无virtaul的子类同名函数"<<endl;
	}
	void print2()
	{
		cout << "有virtual的子类同名函数" << endl;
	}
protected:
};
int main()
{
	A* a = new B;
	a->print1(); //无virtual的父类函数
	a->print2(); //有virtual的子类同名函数
	return 0;
}

纯虚函数和ADT

1.纯虚函数也是虚函数,只是纯虚函数没有函数体

virtual void print()=0;

2.纯虚函数就是做ADT(abstract data type抽象数据类型)过程

3.抽象类:具有至少一个纯虚函数的类,叫抽象类

(1)抽象类不能构建对象

(2)抽象类可构建对象指针

4.纯虚函数没有被重写,无论被继承多少次都是纯虚函数

5.一般抽象类只被继承一次就重写

虚析构函数

在用子类对象初始化父类指针,父类需要虚析构函数做子类内存申请的释放

#include <iostream>
using namespace std;
class A
{
public:
	virtual ~A()
	{
		cout << "父类虚析构" << " ";
	}
protected:
};
class B :public A
{
public:
	~B()
	{
		cout << "子类析构" << " ";
	}
protected:
};
int main()
{
	A* a = new B;
	delete a;
	//子类析构  父类虚析构
	return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个使用C++函数实现多的代码示例: ```cpp #include <iostream> using namespace std; class A { public: virtual void foo() { cout << "A::foo()" << endl; } virtual ~A() { cout << "~A()" << endl; } }; class B : public A { public: void foo() { cout << "B::foo()" << endl; } ~B() { cout << "~B()" << endl; } }; int main() { A* p = new B(); p->foo(); delete p; return 0; } ``` 在这个示例中,类A和类B都有一个名为foo()的函数。当我们通过基类指针p调用foo()函数时,实际上会根据指针所指向的对象的类型来确定调用哪个类的foo()函数。这就是多的实现原理。 输出结果为: ``` B::foo() ~B() ~A() ``` 可以看到,通过函数实现的多,调用的是派生类B的foo()函数,而不是基类A的foo()函数。同时,析构函数也是函数,确保在删除指针p时,会先调用派生类B的析构函数,再调用基类A的析构函数。这是因为在C++中,如果基类的析构函数不是函数,那么通过基类指针删除派生类对象时,只会调用基类的析构函数,而不会调用派生类的析构函数。因此,为了确保正确的析构顺序,析构函数应该声明为函数。 请注意,函数只能在类的成员函数中声明,构造函数不能声明为函数。这是因为在创建对象时,需要先调用构造函数来初始化对象,而函数的机制是在运行时根据对象的类型来确定调用哪个函数,而构造函数在对象创建时就已经确定了。因此,构造函数不能声明为函数。 #### 引用[.reference_title] - *1* [函数实现多原理](https://blog.csdn.net/qq_24309981/article/details/89102183)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [C++函数与多实现](https://blog.csdn.net/qq_27576655/article/details/124535530)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值