继承、虚函数

资料汇集:
https://www.runoob.com/cplusplus/cpp-inheritance.html
https://blog.youkuaiyun.com/qq_35644234/article/details/52825311

继承

C++的面向对象编程是一个非常大的泛式编程,其中类之间的继承是它的一个基本方面。

虚函数

#include <iostream>

class Entity 
{
public:
	std::string Getname() { 
		return "Entity";
	}
};

class Player : public Entity
{
public:
	Player(const std::string& name) : m_name(name) {};
	std::string Getname() {
		return  m_name;
	}

private:
	std::string m_name;
};

int main()
{
	Entity* e = new Entity;
	std::cout << e->Getname() << std::endl;

	Player* p = new Player("Dada");
	std::cout << p->Getname() << std::endl;
	std::cin.get();
}

运行结果:
在这里插入图片描述

#include <iostream>

class Entity 
{
public:
	std::string Getname() { 
		return "Entity";
	}
};

class Player : public Entity
{
public:
	Player(const std::string& name) : m_name(name) {};
	std::string Getname() {
		return  m_name;
	}

private:
	std::string m_name;
};

void PrintName(Entity* entity)
{
	std::cout << entity->Getname() << std::endl;
}

int main()
{
	Entity* e = new Entity;
	PrintName(e);

	Player* p = new Player("Dada");
	PrintName(p);

	std::cin.get();
}

运行结果:
在这里插入图片描述
我们希望C++能够意识到PrintName§调用的Getname()函数实际上是Player中的Getname——这就引出了虚函数的概念。

虚函数实际上引入了一种叫做 Dynamic Dispatch(动态联编)的东西,它通常通过V-Table(虚函数表)来实现编译。v表实际上就是一个表,它包含基类中所有虚函数的映射,这样我们就可以通过它映射到正确的复写(override)函数,在用复写函数之前必须将基类中的基函数标记为虚函数。

虚函数的实现:
在基类的函数前加上 virtual 即可。

 #include <iostream>

class Entity 
{
public:
	virtual std::string Getname() { 
		return "Entity";
	}
};

class Player : public Entity
{
public:
	Player(const std::string& name) : m_name(name) {};
	std::string Getname() 
	 {
		return  m_name;
	}

private:
	std::string m_name;
};

void PrintName(Entity* entity)
{
	std::cout << entity->Getname() << std::endl;
}

int main()
{
	Entity* e = new Entity;
	PrintName(e);

	Player* p = new Player("Dada");
	PrintName(p);

	std::cin.get();
}

这样就可以告诉编辑器,如果这个函数在派生类中被重写了,生成v表并指向正确的映射函数。

运行结果:
在这里插入图片描述

在C++11中还引入了一个新特性,就是在复写函数上标记上override,这样可以在一定程度上避免映射错误。 (注意标记的位置)

#include <iostream>

class Entity 
{
public:
	virtual std::string Getname() { 
		return "Entity";
	}
};

class Player : public Entity
{
public:
	Player(const std::string& name) : m_name(name) {};
	std::string Getname() override {
		return  m_name;
	}

private:
	std::string m_name;
};

void PrintName(Entity* entity)
{
	std::cout << entity->Getname() << std::endl;
}

int main()
{
	Entity* e = new Entity;
	PrintName(e);

	Player* p = new Player("Dada");
	PrintName(p);

	std::cin.get();
}
C++继承虚函数可以按照以下步骤进行: ### 定义基类虚函数 在基类中,使用 `virtual` 关键字来声明虚函数虚函数允许在派生类中被重写,从而实现多态性。例如: ```cpp class Base { public: // 声明虚函数 virtual void func() { std::cout << "Base::func()" << std::endl; } }; ``` ### 定义派生类并继承基类 创建一个派生类,通过继承基类来获取基类的虚函数。 ```cpp class Derived : public Base { // 派生类继承 Base 类 }; ``` ### 重写虚函数(可选但常用) 在派生类中,可以选择重写基类的虚函数。重写时,函数名、参数列表和常量性(如果有)必须与基类的虚函数一致。可以使用 `override` 关键字来明确表示这是对基类虚函数的重写,这有助于编译器检查错误。 ```cpp class Derived : public Base { public: // 重写基类的虚函数 void func() override { std::cout << "Derived::func()" << std::endl; } }; ``` ### 完整示例代码 ```cpp #include <iostream> class Base { public: virtual void func() { std::cout << "Base::func()" << std::endl; } }; class Derived : public Base { public: void func() override { std::cout << "Derived::func()" << std::endl; } }; int main() { Base* basePtr = new Derived(); basePtr->func(); // 调用 Derived::func() delete basePtr; return 0; } ``` 在这个示例中,`Base` 类包含一个虚函数 `func()`,`Derived` 类继承自 `Base` 类并重写了 `func()` 函数。在 `main` 函数中,使用基类指针指向派生类对象,调用 `func()` 函数时会根据对象的实际类型调用派生类的重写版本,实现了多态性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值