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

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面向对象编程的核心特性理解其实现机制和使用场景对于设计灵活的系统至关重要。

相关文章:

C++虚函数与多态机制

C虚函数与多态机制虚函数是C实现运行时多态的核心机制。通过虚函数表和虚函数指针,C能够在运行时根据对象的实际类型调用相应的函数实现。虚函数的基本语法使用virtual关键字声明,派生类可以重写基类的虚函数。#include #include #includeclass Animal {…...

【AI入门知识点】Harness 是什么?为什么 DeepSeek 要组建 Harness 团队?

最近,DeepSeek 招聘信息中出现了一个越来越高频的关键词——Harness 团队。 很多人第一反应是: Harness 是什么?一种新模型?还是某个框架?为什么 DeepSeek 专门成立团队来做这个?如果你第一次听到这个词&am…...

【AI入门知识点】告别繁琐配置!Claude Code + DeepSeek 直连方案打造最强 VSCode 编程助手

在 AI 编程领域,Claude Code 凭借其强大的 Agent 能力(自动读写文件、执行命令)一直是开发者的梦中情“器”。然而,官方 API 的高昂费用和网络限制,让许多国内开发者望而却步。 这篇文章我们不通过 cc-switch 转发请求…...

pycryptodome导入失败的四大底层原因与诊断方案

1. 这不是pycryptodome的问题,而是你没看清它真正依赖的底层逻辑“ImportError: No module named Crypto”、“AttributeError: module Crypto.Cipher has no attribute AES”、“ModuleNotFoundError: No module named Cryptography_cffi...”——这些报错我过去三…...

Python爬虫实战:爬取论文期刊 文献整理+管理表生成

写论文的时候最烦什么?不是写内容,是找文献和整理文献。相信每个研究生都有过这样的经历:打开十几个浏览器标签页,一篇一篇复制论文标题、作者、期刊、发表时间、摘要,然后粘贴到Excel里,一不小心还会复制错…...

通过curl命令直接测试Taotoken聊天补全接口的配置与调用方法

🚀 告别海外账号与网络限制!稳定直连全球优质大模型,限时半价接入中。 👉 点击领取海量免费额度 通过curl命令直接测试Taotoken聊天补全接口的配置与调用方法 在开发或调试大模型应用时,有时你可能希望绕过高级SDK&am…...

AI代理运行时基础设施:从上下文溢出到持久化事件日志

1. 这不是新赛道,是 runtime 层的“操作系统时刻”来了你有没有在深夜调试一个跑了三小时的 AI 代理,突然发现它开始胡言乱语?不是模型崩了,不是 prompt 写错了,而是——它的“记忆”被挤掉了。上下文窗口就那么大&…...

AI绘画中的诡异谷:从技术缺陷到可控美学的跃迁

1. 项目概述:当AI画笔开始颤抖——我们为什么该认真对待“诡异谷”里的美你有没有盯着一张AI生成的肖像画,越看越不对劲?眼睛太亮、皮肤太滑、手指多了一节,或者笑容弧度精准得像用圆规画出来的——那种说不上来哪里怪&#xff0c…...

2026出纳岗位新人如何快速提升能力:从基础上手到能力跃升的最快路径

2026年,出纳岗位已经不再只是“收付款、跑银行、登记现金日记账”这么简单。随着企业财务数字化、业财一体化和AI工具普及,新人想快速成长,必须同时具备规范意识、系统操作能力、数据思维和风险意识。这也是为什么越来越多财务新人会关注像CD…...

Mythos架构解析:大模型的可编程推理能力与Gated Release机制

1. 项目概述:一次被刻意“锁住”的能力跃迁如果你最近关注大模型前沿动态,大概率在技术社区、AI从业者群或邮件列表里见过“TAI #200”这个编号——它不是某篇论文的DOI,也不是某个开源项目的Release Tag,而是The AI Alignment Ne…...

SSH安全加固:禁用弱加密算法的实操指南

1. 为什么禁用弱加密算法不是“可选项”,而是SSH上线前的必过门槛我第一次在客户现场接手一台刚部署的CentOS 7跳板机时,安全扫描报告里赫然标红了三条:ssh-rsa签名算法被标记为CRITICAL,diffie-hellman-group1-sha1密钥交换被判定…...

Claude Mythos:AI驱动的自动化漏洞挖掘与攻防范式跃迁

1. 项目概述:一场静默却震耳欲聋的AI能力跃迁这周,整个AI安全圈没有爆炸性新闻稿,没有铺天盖地的发布会直播,只有一份措辞克制、数据密集的系统卡片(System Card)和一份由英国AI安全研究所(AISI…...

Python自动化登录:破解验证码与Cookie会话维持实战

1. 这不是“绕过验证”,而是理解会话机制的起点很多人看到“跳过验证码登陆”第一反应是:这合规吗?会不会被封?其实这个问题本身就暴露了一个关键误区——我们不是在“绕过”什么,而是在还原真实用户登录时浏览器自动完…...

工业AI落地:从数据冷启动到高质数据工程实战

1. 为什么“数据为中心”不是口号,而是工程现场的真实压力去年冬天,我帮一家做工业缺陷检测的初创公司做模型交付。他们拿来的数据集只有237张标注图,全是产线停机时人工拍的——光照不均、角度单一、连螺丝孔都只拍正面。当时团队信心满满&a…...

DeepSeek总结的从 DuckDB 迁移到 chDB基准测试

来源: https://github.com/chdb-io/cookbook/tree/main/migration-from-duckdbBENCHMARK.md 迁移基准测试 —— 深度探讨 本文是从 DuckDB 迁移到 chDB指南的配套文档。指南的第 5 节将环境/场景/结果/摘要内联呈现;本文件则包含不适合指南风格流程的部分&#xf…...

工业级房价预测实战:从数据清洗到可解释模型部署

1. 这不是“调个模型就完事”的房价预测——而是一次完整的工业级回归建模实战复盘你打开Kaggle,下载一个带“house price”字样的CSV文件,pandas读进来,train_test_split切两刀,RandomForestRegressor.fit()跑完,R显示…...

Anthropic Managed Agents:AI 运行时的事件日志革命

1. 这不是新赛道,是 runtime 层的“操作系统时刻”来了你有没有试过让一个 AI 代理连续工作四十分钟?不是闲聊,而是真正在查文档、调 API、写代码、改配置、再验证——一环扣一环地推进一个真实业务流程。我去年就带着团队跑过这样一个销售线…...

Mumu模拟器ADB连接Unity Profiler全攻略

1. 为什么连不上Mumu的ADB,90%的人卡在第一步就放弃了“ADB device not found”、“offline”、“unauthorized”,这几个词我去年在Unity项目组的晨会白板上写了整整三周。不是因为技术多难,而是因为Mumu模拟器的ADB服务默认不走标准路径&…...

RESTful API测试:从Postman点按到契约级可信的四层验证

1. 为什么RESTful API测试不是“把URL填进去点一下”就能完事?很多人第一次接触接口测试,看到Postman里输入一个GET请求、点下Send,返回200和一串JSON,就以为“测完了”。我带过三届测试新人,几乎每个人都踩过这个坑&a…...

案发现场时空回溯:UWB无法全域留痕,无感定位全链路可复盘

案发现场时空回溯:UWB无法全域留痕,无感定位全链路可复盘镜像视界浙江科技有限公司,作为数字孪生、视频孪生领域底层原创技术核心供给方,依托国家十四五重点课题专项研究、镜像视界浙江普陀时空大数据应用技术联合研究院深度产学研…...

无授权不感知、无穿戴可溯源:无感定位重构公安新型治安底座

无授权不感知、无穿戴可溯源:无感定位重构公安新型治安底座镜像视界浙江科技有限公司依托国家十四五重点课题研究成果、镜像视界浙江普陀时空大数据应用技术联合研究院联合研发体系与河南省电检院权威认证资质,以自研空间计算技术为根基打磨无感定位体系…...

JMeter HTTP接口压测实战:定位性能瓶颈的工程方法论

1. 这不是点几下就能出报告的“压测”,而是对系统真实承压能力的外科手术式探查很多人第一次打开JMeter,以为只要填个URL、设个线程数、点“启动”,跑完看个聚合报告就叫“压测完了”。我见过太多团队在上线前用JMeter跑出“99.9%成功率、平均…...

讲讲libevent底层机制

在 Linux 高并发网络编程领域,libevent 是最经典、最老牌的事件驱动 IO 库,Nginx、Redis、memcached、Tor 等知名项目都基于它二次开发。它封装了 select/poll/epoll/kqueue 等 IO 复用接口,实现了统一的事件驱动模型、定时器、信号处理&…...

FairyGUI GLoader动效动态接管与运行时替换实战

1. 这不是简单的“换图”,而是动效资源的动态接管机制在 FairyGUI for Unity 项目里,当你看到GLoader组件上挂着一个.png或.jpg,心里默认它就是张静态图——但一旦你给它赋值一个MovieClip、GAnimation,甚至是一段从 AssetBundle …...

Unity风格化山脉管线:轮廓生成+分层材质+程序植被

1. 这不是“又一个山体素材包”,而是一套可工业化复用的风格化地形生产管线你有没有试过在Unity里拖进一个山体模型,调整光照后发现——它看起来像照片,但就是不像《原神》《空之轨迹》或者《Ori》里那种呼吸感十足的、带着手绘温度的山&…...

GPT-4稀疏激活机制解析:1.8万亿参数为何仅用2%

1. 项目概述:参数规模与稀疏激活的真相拆解“GPT-4 Has 1.8 Trillion Parameters. It Uses 2% of Them Per Token.”——这句话过去两年在技术社区被反复引用、误读、放大,甚至成为AI算力焦虑的具象化符号。但作为从2017年就开始部署LSTM语音模型、2019年…...

Python之enc-dotenv包语法、参数和实际应用案例

Python enc-dotenv 包完整详解 enc-dotenv 是加密版 python-dotenv 核心增强包,专门解决明文存储环境变量(密钥、密码、Token) 的安全风险。它能将 .env 文件加密存储,运行时自动解密加载,彻底避免敏感配置明文泄露。 …...

潜变量扩散模型原理解析:从宝可梦生成看LDM工程落地

1. 项目概述:用宝可梦讲清楚潜变量扩散模型,不是比喻游戏,是真能跑通的原理复现你有没有试过让AI画一只“皮卡丘和喷火龙杂交出来的电火属性神兽”?不是简单拼贴,而是真正理解“电系的毛发质感火系的鳞片过渡神兽级别的…...

ThingsVis v1.1.15 版本更新:补齐嵌入与运维体验短板,多场景集成更可靠

ThingsVis v1.1.15:嵌入与运维体验的全面升级ThingsVis v1.1.15 版本以 ThingsVis 嵌入能力和设备详情页体验为核心进行更新。在 ThingsVis 嵌入方面,支持全屏、自动播放、剪贴板写入权限,修复 iframe 无法全屏问题;在设备详情页&…...

Unity XLua调试失败原因与sourceMapPathOverrides终极配置

1. 这不是“配个插件就能跑”的事:为什么90%的UnityXLua调试配置会卡在“找不到源码”上EmmyLua VSCode 调试 XLua,这个组合在Unity Lua热更项目里几乎是事实标准。但你有没有遇到过这样的场景:断点明明打在Lua文件里,VSCode也显…...