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

函数指针 + 结构体 = C 语言的“对象模型”?——从 C 到 C++ / Java 的本质统一

一、为什么 C 语言“没有对象”,却处处是对象?

很多人说:

C 是面向过程,C++ / Java 是面向对象。

但你只要看过 Linux 内核、驱动、HAL、FFmpeg、libc,就会发现:

👉到处都是 struct + 函数指针。

比如经典结构:

typedef struct { void (*open)(void* self); void (*close)(void* self); } DeviceOps; typedef struct { DeviceOps* ops; int fd; } Device; void device_open(Device* d) { d->ops->open(d); }

这真的只是“面向过程”吗?

其实不是。
👉这是 C 语言手写的“对象模型”。

tips:对象模型”可以简单理解为:像 Java 里定义接口 → 写接口实现类 → 用实现类对象,通过接口去调用方法。

二、这段 C 代码,本质上已经具备 OOP 全套能力

上面这段代码已经同时具备:

  • ✅ 数据(fd)

  • ✅ 行为(open / close)

  • ✅ 接口抽象(DeviceOps)

  • ✅ 回调机制(函数指针)

  • ✅ 多态(ops 指向不同实现)

  • ✅ this/self 机制(void* self)

这在设计层面,已经是一个完整的“对象系统”。

三、逐项拆解:C 是如何“手搓 OOP”的

1️⃣ 接口(函数表)

typedef struct { void (*open)(void* self); void (*close)(void* self); } DeviceOps;

这本质就是:
👉接口 / 虚函数表 / 回调集合

2️⃣ 对象(数据 + 接口指针)

typedef struct { DeviceOps* ops; int fd; } Device;

等价于:

  • 成员变量
  • 虚函数表指针

3️⃣ 方法调用(多态)

d->ops->open(d);

这里发生了三件事:

  • 通过 ops 找接口
  • 通过接口找实现
  • 把 d 作为 self 传入

👉 这就是虚函数调用

四、翻译成 Java,会发生什么?

C 版本核心调用

d->ops->open(d);

Java 直译版

d.ops.open(d);

Java 正统面向对象写法

d.open();

因为:

  • C 需要你手动维护 self
  • Java 编译器 / 虚拟机帮你维护 this

Java 完整对应结构

接口(C 的 DeviceOps)
interface Device { void open(); void close(); }

实现类(某个具体设备)

class FileDevice implements Device { int fd; @Override public void open() { } }

多态调用

Device d = new FileDevice(); d.open();

👉 本质和 C 的:

d->ops->open(d);

完全一致。

五、翻译成 C++,你会看到“虚函数表真身”

class Device { public: virtual void open() = 0; virtual void close() = 0; int fd; };

编译器背后做的事情,和你在 C 里写的:

DeviceOps* ops;

几乎一模一样。

👉 C++ 只是帮你自动生成并维护了那张函数表。

六、函数指针模型 = 回调模型 = 对象模型

普通回调:

register_callback(on_event);

对象模型:

device->ops->on_event(device);

区别只有一个:

👉 对象模型 =一组有语义的回调 + 绑定的数据结构

这也是为什么系统层大量使用 struct + 函数指针:

  • Linux driver
  • Binder driver
  • HAL module
  • FFmpeg / libuv / libc

👉 全部都是“接口 + 实现 + 回调 + 多态”。

七、为什么系统层更爱 C 风格“对象模型”?

因为它:

  • ✅ ABI 稳定

  • ✅ 内存布局可控

  • ✅ 无运行时依赖

  • ✅ 跨语言

  • ✅ 性能可预测

  • ✅ 可用于内核 / 驱动 / 启动阶段

而 C++ / Java:

  • 是在此模型之上,提供自动化和安全封装。

八、一句话本质总结(系统工程师版)

👉 面向对象不是语法,是设计思想。
👉 C 用函数指针实现对象。
👉 C++ 用编译器实现对象。
👉 Java 用虚拟机实现对象。

九、对 NDK / Android 系统方向的意义

你以后会不断看到:

  • Binder 的 struct + ops

  • HAL 的 hw_module_t

  • Linux 的 file_operations

  • FFmpeg 的 AVCodec

你会发现:

👉它们全都是这一个模型。

当你真正理解“函数指针 + struct = 对象模型”,你就已经具备:

✅ 系统接口设计能力
✅ 框架层阅读能力
✅ 架构抽象能力

十、终极总结

C :手动对象系统
C++ :编译器对象系统
Java :虚拟机对象系统

底层实现不同,抽象思想完全统一。

http://www.jsqmd.com/news/230822/

相关文章:

  • 灰狼优化算法(GWO)改进物理信息神经网络(PINN) - 光伏功率预测附Matlab代码
  • 2022蓝帽杯计算机取证
  • k8s 各版本变更记录
  • 1. 2025 年终总结 PPT 愁死人?这 3 款 AI
  • 麻雀算法SSA 差分算法DE GA遗传算法的光伏阵列参数辨识附matlab代码
  • 【数据集】中国杰出青年名单数据集(1994-2024年)
  • 圆度误差的神经网络评定及测量不确定度研究附Matlab代码
  • 数字员工如何通过AI销冠系统与AI提效软件系统推动企业智能化升级
  • 【SCI创新】ASL-QPSO-SVM时序预测算法研究——基于动态非线性收缩扩张因子、正余弦惯性权重与莱维-贪婪融合策略附Matlab代码
  • 数字员工是什么?AI销冠系统与AI提效软件系统的价值在哪里?
  • 【SCI二区IEEE复现】基于混合有限集模型预测控制(FCS-MPC)的模块化多电平换流器(MMC)整流电路仿真模型附Simulink仿真
  • Agent Skills (Claude Skills) 详细攻略,一篇文章精通
  • 基于AHP-EWM正态云模型的初中地理教学评价附Matlab代码
  • 【SCI复现】高比例可再生能源并网如何平衡灵活性与储能成本?虚拟电厂多时间尺度调度及衰减建模附Matlab代码
  • 【无人机追踪】基于Dubin和候选集的无人机UAV集群协同攻击目标的Matlab仿真程序,围绕无人机的目标搜索、冲突避免、联盟组建和任务执行展开考虑能和
  • 学长亲荐9个AI论文平台,研究生高效写作必备!
  • 【SCI一区】【电动车】基于ADMM双层凸优化的燃料电池混合动力汽车研究附Matlab代码
  • Claude Code + Codex + Gemini 似乎已经成为高手总结的AI编程最佳实践方案
  • 导师严选2026 AI论文网站TOP9:继续教育写作全攻略
  • 高精度智慧城市建筑物巡检识别 建筑物立面缺陷识别 墙面裂缝检测数据集 表面裂纹图像识别数据集 工程质量巡检图像数据集第10381期
  • 【GA-HIDMSPSO-CNN-SVM】 基于 GA-HIDMSPSO 优化 CNN-SVM 分类研究附Matlab代码
  • php+uniapp平台的校园生活服务交流论坛系统(二手,失物招领 -跑腿) 小程序
  • SpringBoot邮件发送功能模版
  • 【GPS+INS在MAV导航上融合】基于间接卡尔曼滤波的IMU与GPS融合MATLAB仿真(IMU与GPS数据由仿真生成)附Matlab代码
  • php+uniapp食品安全信息检测管理系统 小程序_36kb0
  • 【Koopman 算子】深度学习用于非线性动力学的通用线性嵌入研究附Python、Matlab代码
  • 通过AI技术提升电商服务质量的策略
  • 【SCI】【分数阶极值寻优控制】极值寻优控制(ESC)的新的最大功率点跟踪(MPPT)研究附Simulink仿真
  • php+uniapp高校社团管理小程序的设计与实现
  • 无线数据通信技术【1.1】