当前位置: 首页 > news >正文

C++虚函数与多态机制

C虚函数与多态机制虚函数是C实现运行时多态的核心机制。通过虚函数表和虚函数指针C能够在运行时根据对象的实际类型调用相应的函数实现。虚函数的基本语法使用virtual关键字声明派生类可以重写基类的虚函数。#include#include#includeclass Animal {public:virtual ~Animal() default;virtual void make_sound() const {std::cout Animal makes a sound\n;}virtual void move() const {std::cout Animal moves\n;}void describe() const {std::cout This is an animal\n;}};class Dog : public Animal {public:void make_sound() const override {std::cout Dog barks: Woof!\n;}void move() const override {std::cout Dog runs on four legs\n;}};class Cat : public Animal {public:void make_sound() const override {std::cout Cat meows: Meow!\n;}void move() const override {std::cout Cat walks gracefully\n;}};void polymorphism_basic() {std::vector animals;animals.push_back(std::make_unique());animals.push_back(std::make_unique());animals.push_back(std::make_unique());for (const auto animal : animals) {animal-make_sound();animal-move();std::cout ---\n;}}纯虚函数使用0语法声明包含纯虚函数的类是抽象类不能实例化。class Shape {public:virtual ~Shape() default;virtual double area() const 0;virtual double perimeter() const 0;virtual void draw() const 0;};class Circle : public Shape {double radius_;public:explicit Circle(double r) : radius_(r) {}double area() const override {return 3.14159 * radius_ * radius_;}double perimeter() const override {return 2 * 3.14159 * radius_;}void draw() const override {std::cout Drawing circle with radius radius_ \n;}};class Rectangle : public Shape {double width_, height_;public:Rectangle(double w, double h) : width_(w), height_(h) {}double area() const override {return width_ * height_;}double perimeter() const override {return 2 * (width_ height_);}void draw() const override {std::cout Drawing rectangle width_ x height_ \n;}};void abstract_class_example() {std::vector shapes;shapes.push_back(std::make_unique(5.0));shapes.push_back(std::make_unique(4.0, 6.0));double total_area 0;for (const auto shape : shapes) {shape-draw();total_area shape-area();std::cout Area: shape-area() , Perimeter: shape-perimeter() \n;}std::cout Total area: total_area \n;}虚函数表是编译器实现虚函数的机制每个包含虚函数的类都有一个虚函数表。class Base {public:virtual void func1() { std::cout Base::func1\n; }virtual void func2() { std::cout Base::func2\n; }virtual ~Base() default;};class Derived : public Base {public:void func1() override { std::cout Derived::func1\n; }void func3() { std::cout Derived::func3\n; }};void vtable_demonstration() {Base* ptr new Derived();ptr-func1();ptr-func2();delete ptr;std::cout Size of Base: sizeof(Base) \n;std::cout Size of Derived: sizeof(Derived) \n;}多重继承中的虚函数需要特别注意菱形继承问题。class Device {public:virtual ~Device() default;virtual void power_on() 0;virtual void power_off() 0;};class Printer : virtual public Device {public:void power_on() override {std::cout Printer powered on\n;}void power_off() override {std::cout Printer powered off\n;}virtual void print(const std::string doc) {std::cout Printing: doc \n;}};class Scanner : virtual public Device {public:void power_on() override {std::cout Scanner powered on\n;}void power_off() override {std::cout Scanner powered off\n;}virtual void scan() {std::cout Scanning document\n;}};class MultiFunctionDevice : public Printer, public Scanner {public:void power_on() override {std::cout Multi-function device powered on\n;}void power_off() override {std::cout Multi-function device powered off\n;}};void multiple_inheritance_example() {MultiFunctionDevice mfd;mfd.power_on();mfd.print(document.pdf);mfd.scan();mfd.power_off();}final关键字可以防止类被继承或虚函数被重写。class FinalClass final {public:virtual void func() {std::cout FinalClass::func\n;}};class BaseWithFinal {public:virtual void can_override() {std::cout BaseWithFinal::can_override\n;}virtual void cannot_override() final {std::cout BaseWithFinal::cannot_override\n;}};class DerivedFromBase : public BaseWithFinal {public:void can_override() override {std::cout DerivedFromBase::can_override\n;}};协变返回类型允许派生类的虚函数返回更具体的类型。class Product {public:virtual ~Product() default;virtual void use() const 0;};class ConcreteProduct : public Product {public:void use() const override {std::cout Using concrete product\n;}};class Factory {public:virtual ~Factory() default;virtual Product* create() const {return new Product();}};class ConcreteFactory : public Factory {public:ConcreteProduct* create() const override {return new ConcreteProduct();}};虚析构函数确保通过基类指针删除派生类对象时能正确调用派生类的析构函数。class ResourceBase {public:ResourceBase() {std::cout ResourceBase constructor\n;}virtual ~ResourceBase() {std::cout ResourceBase destructor\n;}};class ResourceDerived : public ResourceBase {int* data_;public:ResourceDerived() : data_(new int[100]) {std::cout ResourceDerived constructor\n;}~ResourceDerived() override {delete[] data_;std::cout ResourceDerived destructor\n;}};void virtual_destructor_example() {ResourceBase* ptr new ResourceDerived();delete ptr;}动态类型识别使用dynamic_cast和typeid实现。#includeclass Component {public:virtual ~Component() default;virtual void update() 0;};class GraphicsComponent : public Component {public:void update() override {std::cout Updating graphics\n;}void render() {std::cout Rendering graphics\n;}};class PhysicsComponent : public Component {public:void update() override {std::cout Updating physics\n;}void simulate() {std::cout Simulating physics\n;}};void rtti_example() {std::vector components;components.push_back(std::make_unique());components.push_back(std::make_unique());for (auto comp : components) {comp-update();if (auto* graphics dynamic_cast(comp.get())) {graphics-render();} else if (auto* physics dynamic_cast(comp.get())) {physics-simulate();}std::cout Type: typeid(*comp).name() \n;}}虚函数的性能开销主要来自间接调用和缓存未命中。#includeclass VirtualBase {public:virtual ~VirtualBase() default;virtual int compute(int x) const {return x * x;}};class VirtualDerived : public VirtualBase {public:int compute(int x) const override {return x * x x;}};class NonVirtual {public:int compute(int x) const {return x * x x;}};void performance_comparison() {const int iterations 10000000;VirtualBase* vptr new VirtualDerived();auto start std::chrono::high_resolution_clock::now();volatile int result 0;for (int i 0; i iterations; i) {result vptr-compute(i);}auto end std::chrono::high_resolution_clock::now();auto duration std::chrono::duration_cast(end - start);std::cout Virtual call: duration.count() ms\n;delete vptr;NonVirtual nv;start std::chrono::high_resolution_clock::now();for (int i 0; i iterations; i) {result nv.compute(i);}end std::chrono::high_resolution_clock::now();duration std::chrono::duration_cast(end - start);std::cout Non-virtual call: duration.count() ms\n;}虚函数与模板结合可以实现静态多态和动态多态的混合使用。templateclass Processor {public:void process(const T data) {pre_process();do_process(data);post_process();}virtual ~Processor() default;protected:virtual void pre_process() {std::cout Default pre-processing\n;}virtual void do_process(const T data) 0;virtual void post_process() {std::cout Default post-processing\n;}};class IntProcessor : public Processor {protected:void do_process(const int data) override {std::cout Processing int: data * 2 \n;}};虚函数是C面向对象编程的核心特性理解其实现机制和使用场景对于设计灵活的系统至关重要。
http://www.zskr.cn/news/1361369.html

相关文章:

  • 社交AI Agent不是Chatbot!5个被99%团队忽略的协议层设计陷阱(附LinkedIn/小红书级SDK接口规范)
  • Unity WebGL文本输入解决方案:DOM桥接与IME兼容架构
  • 2026年北京餐饮外卖打包盒厂家推荐:瀚隆包装为什么适合单店与连锁餐饮共同选择? - 企业深度横评dyy6420
  • Docker 日常操作笔记(开发最常用命令)
  • Docker 入门笔记(后端开发必学)
  • WzComparerR2完整指南:冒险岛游戏数据提取与可视化分析工具
  • 线路板清洁度萃取+分析全套设备实力厂家推荐,西恩士工业 - 工业设备研究社
  • 这次终于选对了!高效论文写作全流程AI论文网站推荐(2026 最新)
  • Python爬虫实战:爬取论文期刊 文献整理+管理表生成
  • MoE稀疏激活原理与工程落地实战
  • SSH安全加固:禁用弱加密算法的实操指南
  • 文件上传漏洞深度解析:从getshell到六维纵深防御
  • Linux服务器入侵排查实战:三层切片应急响应流程
  • LSTM为何在工业时序建模中不可替代?梯度消失与门控机制的工程真相
  • 5分钟搞定Windows 11安卓应用安装:WSA Toolbox完全指南
  • [Python实战] 路径、编码、解释器老出问题时,怎样把脚本环境一次性理顺?
  • 无监督跌倒检测:不依赖标注数据的实时异常建模方法
  • Mumu模拟器ADB连接Unity Profiler全攻略
  • 一天干完一百万字,谷歌 agy 这个工具简直是头不要命的洪水猛兽
  • DeepSeek总结的从 DuckDB 迁移到 chDB基准测试
  • OpenSSH PKCS#11双重释放漏洞深度解析与实战防护
  • SQL报错注入实战:MySQL/PostgreSQL/Oracle三库绕过与数据提取
  • CVE-2025-68493深度解析:OGNL沙箱坍塌与Java Web内网横向移动
  • 案发现场时空回溯:UWB无法全域留痕,无感定位全链路可复盘
  • 无授权不感知、无穿戴可溯源:无感定位重构公安新型治安底座
  • 讲讲libevent底层机制
  • 宁夏买家电推荐去哪里 - 资讯纵览
  • AI智能体运行时正走向操作系统化:从血泪工程到基础设施
  • BepInEx插件开发全解析:Unity游戏Mod生态基建指南
  • 大模型规模信仰的科学反思:数据、架构与训练策略的结构性失衡