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

Qt开发:枚举的介绍和使用

文章目录

    • 一、概述
    • 二、Qt 中定义和使用枚举
      • 2.1 普通枚举的定义方式
      • 2.2 使用枚举
    • 三、配合 Qt 元对象系统使用枚举
      • 3.1 使用 Q_ENUM(Qt 5.5 及以上)
      • 3.2 示例:枚举值转字符串
      • 3.4 示例:字符串转枚举值
    • 四、枚举与字符串相互转换
    • 五、枚举与字符串相互转换(通用版)

一、概述

  在 Qt 中,枚举(enum)是一种用于表示一组具有名称的整型常量的类型,广泛用于状态表示、选项设置、信号与槽的参数传递等场景。Qt 的枚举使用方式和 C++ 的标准 enum 类似,但 Qt 也提供了更强的功能,如与 QMetaObject 系统结合、配合 Q_ENUM 或 Q_ENUMS 宏实现枚举值的字符串转换等。

二、Qt 中定义和使用枚举

2.1 普通枚举的定义方式

class MyClass : public QObject {Q_OBJECT
public:enum Status {Idle,Running,Stopped};void setStatus(Status s);
};

2.2 使用枚举

MyClass obj;
obj.setStatus(MyClass::Running);

三、配合 Qt 元对象系统使用枚举

3.1 使用 Q_ENUM(Qt 5.5 及以上)

class MyClass : public QObject {Q_OBJECT
public:enum Status {Idle,Running,Stopped};Q_ENUM(Status)
};

这样做的好处是可以通过 QMetaEnum 反射地访问枚举值,比如将字符串转换为枚举值,或枚举值转换为字符串。

3.2 示例:枚举值转字符串

MyClass::Status status = MyClass::Running;
QMetaEnum metaEnum = QMetaEnum::fromType<MyClass::Status>();
QString name = metaEnum.valueToKey(status);  // 得到 "Running"

3.4 示例:字符串转枚举值

int value = metaEnum.keyToValue("Stopped");  // 得到 2

四、枚举与字符串相互转换

#include <QObject>
#include <QMetaEnum>class StatusHelper : public QObject
{Q_OBJECT
public:enum class Status {Idle = 1,Running,Finished,Error};Q_ENUM(Status)  // 注册枚举到 Qt 元对象系统// 枚举转字符串static QString enumToString(Status s){const QMetaObject &meta = StatusHelper::staticMetaObject;int index = meta.indexOfEnumerator("Status");QMetaEnum metaEnum = meta.enumerator(index);return metaEnum.valueToKey(static_cast<int>(s));}// 字符串转枚举static Status stringToStatus(const QString& str) {const QMetaObject &meta = StatusHelper::staticMetaObject;int index = meta.indexOfEnumerator("Status");QMetaEnum metaEnum = meta.enumerator(index);int value = metaEnum.keyToValue(str.toUtf8().constData());if (value != -1)return static_cast<Status>(value);elsereturn static_cast<Status>(-1); // 或者你定义一个 Invalid 值}
};

代码调用:

#include <QApplication>
#include <QDebug>int main(int argc, char *argv[])
{QApplication app(argc, argv);QString str = StatusHelper::enumToString(StatusHelper::Status::Idle);qDebug() << "str:" << str;StatusHelper::Status s = StatusHelper::stringToStatus(str);qDebug() << s;return app.exec();
}

输出结果:
在这里插入图片描述

五、枚举与字符串相互转换(通用版)

class StatusHelper : public QObject
{Q_OBJECT
public:enum class Status {Idle = 1,Running,Finished,Error,Unknown};Q_ENUM(Status)  // 注册枚举到 Qt 元对象系统// 枚举转字符串template<typename T>static QString enumToString(const QString& strEnumType, T value){const QMetaObject &metaObj = StatusHelper::staticMetaObject;const char* pEnumName = nullptr;// 遍历所有枚举元数据for (int i = 0; i < metaObj.enumeratorCount(); ++i) {QMetaEnum metaEnum = metaObj.enumerator(i);if (QString(metaEnum.name()) == strEnumType) {pEnumName = metaEnum.valueToKey(static_cast<int>(value));break;}}return pEnumName ? QString(pEnumName) : QString("Unknown");}// 字符串转枚举template<typename T>static T stringToEnum(const QString& strEnumType, const QString& strKey, T defaultValue){const QMetaObject &metaObj = StatusHelper::staticMetaObject;for (int i = 0; i < metaObj.enumeratorCount(); ++i) {QMetaEnum metaEnum = metaObj.enumerator(i);if (QString(metaEnum.name()) == strEnumType) {bool bRet = false;int iValue = metaEnum.keyToValue(strKey.toUtf8().constData(), &bRet);if (bRet) {return  static_cast<T>(iValue);}}}return  defaultValue;}
};

代码调用:

#include <QApplication>
#include <QDebug>int main(int argc, char *argv[])
{QApplication app(argc, argv);QString str = StatusHelper::enumToString("Status", StatusHelper::Status::Idle);qDebug() << "str:" << str;StatusHelper::Status s = StatusHelper::stringToEnum("Status", str, StatusHelper::Status::Unknown);qDebug() << s;return app.exec();
}

输出结果:
在这里插入图片描述

相关文章:

  • eFish-SBC-RK3576工控板外部RTC测试操作指南
  • SpringBoot项目接入DeepSeek
  • Linux:web服务nginx
  • Pinecone向量库 VS Redis
  • 大模型工具与案例:云服务器部署dify(1)
  • 递归element-ui el-menu 实现无限级子菜单
  • Nginx 搭建支持多版本和前端路由的静态网站
  • 初始图形学(7)
  • C++并发编程完全指南:从基础到实践
  • 准确---Typora配置Gitee图床并实现自动图片上传
  • Windows环境下maven的安装与配置
  • 实践003-Gitlab CICD编译构建
  • 隐私计算技术及其在数据安全中的应用:守护数据隐私的新范式
  • python 闭包获取循环数据经典 bug
  • 滑动窗口——长度最小子数组
  • Go 并发错误处理利器:深入理解 errgroup
  • Kafka的消息保留策略是怎样的? (基于时间log.retention.hours或大小log.retention.bytes,可配置删除或压缩策略)
  • 【前端基础】7、CSS的字体属性(font相关)
  • 《Python星球日记》 第47天:聚类与KMeans
  • 学习笔记:黑马程序员JavaWeb开发教程(2025.3.30)
  • “毛茸茸”的画,诗意、温暖又治愈
  • 人民财评:网售“婴儿高跟鞋”?不能让畸形审美侵蚀孩子身心
  • 一周文化讲座|城市移民与数字时代的新工作
  • 印度外交秘书:“朱砂行动”不针对军事设施,无意升级事态
  • 以军总参谋长:已进入“决定性打击计划的第二阶段”
  • 李公明︱一周书记:浪漫主义为什么……仍然重要?