【QT】-QT为啥喜欢用类而不是结构体

Qt 为什么用 class 而不是 struct 封装 QPoint、QRect 等?

这是个很有深度的设计问题!答案涉及 C++ 历史、Qt 哲学、二进制兼容性 等。

首先澄清:QPoint 其实"像 struct",但声明为 class

在 Qt 源码中,QPoint 是这样定义的(简化):

cpp 复制代码
class QPoint {
public:
    int x, y;
    QPoint() : x(0), y(0) {}
    QPoint(int xpos, int ypos) : x(xpos), y(ypos) {}
    // 各种运算符重载:+、-、== 等
};

虽然用 class 关键字,但:

所有成员都是 public

没有虚函数

没有复杂逻辑

行为上完全像 C 的 struct

那为什么不用 struct?

  1. C++ 中 class 和 struct 几乎一样
    唯一区别:默认访问权限(class 默认 private,struct 默认 public)
    Qt 选择 class 是为了 统一风格 ------ Qt 中几乎所有类型都是 class,包括简单类型。
  2. 历史与兼容性考虑
    Qt 诞生于 1990 年代,当时 C++ 编译器对 struct 支持不如现在稳定。
    用 class 更"面向对象",符合 Qt 的设计理念(即使简单类型也提供方法)。
  3. 未来可扩展性
    今天 QPoint 很简单,但未来可能需要:
    添加方法(如 QPoint::manhattanLength())
    支持隐式共享(像 QVector 那样)
    适配高 DPI(虽然现在还是整数)
    用 class 可以在不破坏 ABI 的情况下加 private 成员(struct 通常被视为 POD,加成员会破坏内存布局)。
  4. Qt 的哲学:一切皆对象
    Qt 希望即使是坐标、矩形这样的"值类型",也能有方法和行为:
cpp 复制代码
QPoint p(10, 20);
p += QPoint(5, 5);     // 运算符重载
int len = p.manhattanLength(); // 方法

这比纯 C 风格的 struct + 全局函数更面向对象。

  1. 与 QObject 体系保持一致

虽然 QPoint 不是 QObject,但 Qt 整体 API 风格统一用 class,降低用户认知负担。

Qt 选择了更现代、更安全、更易用的面向对象封装。

总结

为什么用class而不是struct?

  1. 统一 Qt 风格
  2. 支持方法和运算符重载
  3. 便于未来扩展
  4. 符合面向对象设计
  5. 历史和 ABI 兼容性考虑

小知识:在 Qt 中,QPoint、QSize、QRect 等被称为 "值类型(value types)",它们设计得像 int 一样轻量、可复制,但又有面向对象的便利性。

相关推荐
清水白石0084 小时前
从打印对象到高质量调试:彻底理解 Python 中 `__repr__` 和 `__str__` 的区别
开发语言·python
枕星而眠4 小时前
C++ 面向对象核心机制深度解析:多态性、虚函数、虚继承与 final 类
运维·开发语言·c++·后端
Evand J4 小时前
【MATLAB例程】自适应渐消扩展卡尔曼滤波(AFEKF)三维雷达目标跟踪|效果已调优,附下载链接和运行结果,代码直接运行即可
开发语言·算法·matlab·目标跟踪·卡尔曼滤波·自适应滤波·代码定制
爱装代码的小瓶子4 小时前
3. 设计buffer模块
linux·服务器·开发语言·c++·php
郝学胜-神的一滴5 小时前
Qt 高级开发 027: QTabWidget自定义样式表美化实战
开发语言·c++·qt·程序人生·软件构建·用户界面
keykey6.5 小时前
迁移学习实战:用预训练模型做图像分类
开发语言·人工智能·深度学习·机器学习
双河子思5 小时前
《代码整洁之道》——读书笔记(持续更新)
开发语言·c++·c#
川冰ICE5 小时前
JavaScript实战②|电商网站交互效果,轮播图与购物车
开发语言·javascript·交互
listhi5205 小时前
基于 Qt 5.8.0 的串口调试助手
开发语言·qt
sugar__salt5 小时前
Bun 新一代 JavaScript/TypeScript 运行时:从入门到实战
开发语言·javascript·typescript