QT枚举类型转字符串和使用QDebug<<重载输出私有枚举类型

一 将QT自带的枚举类型转换为QString

需要的头文件:

cpp 复制代码
#include <QMetaObject>
#include <QMetaEnum>

测试代码

cpp 复制代码
   const QMetaObject *metaObject = &QImage::staticMetaObject;
    QMetaEnum metaEnum = metaObject->enumerator(metaObject->indexOfEnumerator("Format"));
    QString formatString = metaEnum.valueToKey(image1.format());
    qDebug() << "formatString = " << formatString;

测试输出的结果:

formatString = "Format_Mono"

二 通过qdebug<<重载自己的私有枚举

1 修改类

添加自己的枚举类型和枚举类型转字符串函数:

cpp 复制代码
class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    MainWindow(QWidget *parent = nullptr);
    ~MainWindow();

    enum myenum{
        MY_ENUM_ONE,
        MY_ENUM_TWO,
    };

    static QString toString(myenum value) {
        switch (value) {
        case MY_ENUM_ONE: return "MY_ENUM_ONE";
        case MY_ENUM_TWO: return "MY_ENUM_TWO";
        default: return "Unknown";
        }
    }
}

2 添加QDebug的<<新的重载方法

然后,为 QDebug 类提供一个重载的 operator<<() 方法:

cpp 复制代码
// 为 QDebug 提供重载的 operator<<,用于输出 MainWindow::myenum 类型的值
QDebug operator<<(QDebug debug, MainWindow::myenum value) {
    QDebugStateSaver saver(debug); // 保存 QDebug 的当前状态
    debug.nospace() << MainWindow::toString(value); // 输出枚举值的字符串表示
    return debug;
}

3 添加测试代码

在构造函数中添加测试代码:

cpp 复制代码
    enum myenum one = myenum::MY_ENUM_ONE;
    qDebug() << one;

4 测试结果:

三 将私有枚举转字符串

这样就可以了

cpp 复制代码
    static QString toString(myenum value) {
        switch (value) {
        case MY_ENUM_ONE: return "MY_ENUM_ONE";
        case MY_ENUM_TWO: return "MY_ENUM_TWO";
        default: return "Unknown";
        }
    }

小结

相关推荐
chao_7891 小时前
回溯题解——子集【LeetCode】二进制枚举法
开发语言·数据结构·python·算法·leetcode
cpp_learners2 小时前
QML与C++交互之创建自定义对象
c++·qt·qml
尘世闲鱼2 小时前
解数独(C++版本)
开发语言·c++·算法·解数独
纨妙3 小时前
python打卡day59
开发语言·python
wuxuanok3 小时前
Web后端开发-请求响应
java·开发语言·笔记·学习
Sally璐璐4 小时前
IPSAN 共享存储详解:架构、优化与落地实践指南
开发语言·php
像风一样的男人@4 小时前
python --货车装厢问题
开发语言·python
Humbunklung4 小时前
Rust枚举:让数据类型告别单调乏味
开发语言·后端·rust
Y1nhl4 小时前
力扣_链表_python版本
开发语言·python·算法·leetcode·链表·职场和发展
OEC小胖胖4 小时前
深入理解 Vue.js 响应式原理及其在 Web 前端开发中的应用
开发语言·前端·javascript·vue.js·web