Qt工作笔记-两种方法从容器中筛选出父类和子类(继承法、typeid法)

583 篇文章 127 订阅
388 篇文章 20 订阅

两种方法程序运行界面效果都一样!

程序运行截图如下:


这个图随便看看就可以了,没啥用!


代码如下:

widget.h

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include <QListWidgetItem>
#include <QVector>

namespace Ui {
class Widget;
}

class MyListWidgetItem:public QListWidgetItem{
public:
    bool isVisited; //在此编译器中,这个值默认是false
};


class Widget : public QWidget
{
    Q_OBJECT

public:
    explicit Widget(QWidget *parent = 0);
    ~Widget();

public slots:
    void selectBtnClicked();

private:
    Ui::Widget *ui;
    QVector<QListWidgetItem*> m_data;
};

#endif // WIDGET_H

widget.cpp

#include "widget.h"
#include "ui_widget.h"

#include <QDebug>
#include <QTime>
#include <QTimer>
#include <typeinfo>

Widget::Widget(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::Widget)
{
    ui->setupUi(this);

    qsrand(QTime(0,0,0).secsTo(QTime::currentTime()));

    for(int i=0;i<10000;i++){
        if(i>=0&&i<999){
            int randData=qrand()%100000+100;
            QString msg="对方发出"+QString::number(randData)+"未处理!";
            QListWidgetItem *listData=new QListWidgetItem;
            listData->setText(msg);
            m_data.append(listData);
        }
        else{
            int randData=qrand()%100000+100;
            QString msg="对方发出"+QString::number(randData)+"未处理!";
            MyListWidgetItem *listData=new MyListWidgetItem;
            listData->setText(msg);
            m_data.append(listData);
        }
    }

    connect(ui->pushButton,&QPushButton::clicked,this,&Widget::selectBtnClicked);
}

Widget::~Widget()
{
    for(int i=0;i<m_data.size();i++){
        delete m_data[i];
    }
    delete ui;
}

void Widget::selectBtnClicked()
{
    //方法一:利用typeinfo
    QVector<QListWidgetItem*>::iterator it=m_data.begin();
    while(it!=m_data.end()){
        if(QString(typeid(**it).name()).contains("MyListWidgetItem")){
            ui->listWidget->insertItem(0,(*it));
        }
        it++;
    }
}

main.cpp

#include "widget.h"
#include <QApplication>

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    Widget w;
    w.show();

    return a.exec();
}

这里的方法为typeid

void Widget::selectBtnClicked()
{
    //方法一:利用typeinfo
    QVector<QListWidgetItem*>::iterator it=m_data.begin();
    while(it!=m_data.end()){
        if(QString(typeid(**it).name()).contains("MyListWidgetItem")){
            ui->listWidget->insertItem(0,(*it));
        }
        it++;
    }
}

获取类名,看看有没有包含MyListWidgetItem这个字符串。

这里要用到**it


第二种是继承法,得把m_data的数据类型改变,这个方法是很传统的方法。

代码如下:

widget.h

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include <QListWidgetItem>
#include <QVector>

namespace Ui {
class Widget;
}

class MyListWidgetItem:public QListWidgetItem{
public:
    bool isVisited; //在此编译器中,这个值默认是false
};


class Widget : public QWidget
{
    Q_OBJECT

public:
    explicit Widget(QWidget *parent = 0);
    ~Widget();

public slots:
    void selectBtnClicked();

private:
    Ui::Widget *ui;
    QVector<MyListWidgetItem*> m_data;
};

#endif // WIDGET_H


main.cpp

#include "widget.h"
#include <QApplication>

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);
    Widget w;
    w.show();

    return a.exec();
}


widget.cpp

#include "widget.h"
#include "ui_widget.h"

#include <QDebug>
#include <QTime>
#include <QTimer>
#include <typeinfo>

Widget::Widget(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::Widget)
{
    ui->setupUi(this);

    qsrand(QTime(0,0,0).secsTo(QTime::currentTime()));

    for(int i=0;i<10000;i++){
        if(i>=0&&i<999){
            int randData=qrand()%100000+100;
            QString msg="对方发出"+QString::number(randData)+"未处理!";
            MyListWidgetItem *listData=new MyListWidgetItem;
            listData->isVisited=true;
            listData->setText(msg);
            m_data.append(listData);
        }
        else{
            int randData=qrand()%100000+100;
            QString msg="对方发出"+QString::number(randData)+"未处理!";
            MyListWidgetItem *listData=new MyListWidgetItem;
            listData->setText(msg);
            m_data.append(listData);
        }
    }

    connect(ui->pushButton,&QPushButton::clicked,this,&Widget::selectBtnClicked);
}

Widget::~Widget()
{
    for(int i=0;i<m_data.size();i++){
        delete m_data[i];
    }
    delete ui;
}

void Widget::selectBtnClicked()
{
    //方法一:利用typeinfo
//    QVector<QListWidgetItem*>::iterator it=m_data.begin();
//    while(it!=m_data.end()){
//        if(QString(typeid(**it).name()).contains("MyListWidgetItem")){
//            ui->listWidget->insertItem(0,(*it));
//        }
//        it++;
//    }

    //方法二,继承

    for(int i=0;i<m_data.size();i++){
        if(!m_data[i]->isVisited){
            ui->listWidget->insertItem(0,m_data[i]);
        }
    }

}

下面是我为您编写的代码,包括.h和.cpp文件: test.h ``` #ifndef TEST_H #define TEST_H #include <QtCore> struct SP104 { quint8 addr0; quint8 addr1; quint8 addr2; }; struct DP104 { quint8 addr0; quint8 addr1; quint8 addr2; QString data; }; template <typename T> class Test { public: Test() { int type = QMetaType::type(qPrintable(typeid(T).name())); if (type != QMetaType::UnknownType) { qDebug() << "Type" << typeid(T).name() << "is registered with QMetaType"; } else { qRegisterMetaType<T>(qPrintable(typeid(T).name())); qDebug() << "Type" << typeid(T).name() << "has been registered with QMetaType"; } } void test() { if (t_map.isEmpty()) { qDebug() << "t_map is empty"; } else { qDebug() << "t_map is not empty"; } if (t_cache.isEmpty()) { qDebug() << "t_cache is empty"; } else { qDebug() << "t_cache is not empty"; } if (t_vctor.isEmpty()) { qDebug() << "t_vctor is empty"; } else { qDebug() << "t_vctor is not empty"; } } private: QMap<QString, QVector<T>> t_map; QCache<QString, QVector<T>> t_cache; QVector<T> t_vctor; }; #endif // TEST_H ``` test.cpp ``` #include "test.h" template class Test<SP104>; template class Test<DP104>; ``` 在这个示例,我们首先定义了两个自定义结构体 SP104和DP104,然后定义了一个泛型类 Test,该类可以使用不同的自定义类型,即 SP104和DP104。 在 Test 类的构造函数,我们使用 QMetaType::type() 函数获取自定义类型,并检查该类型是否已经在 QMetaType 注册。如果类型已经注册,则打印一条消息表明类型已经注册。否则,我们使用 qRegisterMetaType() 函数将该类型注册到 QMetaType ,并打印一条消息表明已经注册了该类型。 在 Test 类的 test() 函数,我们检查 t_map、t_cache 和 t_vctor 是否为空,并打印相应的消息。 在 test.cpp 文件,我们使用 template class Test<SP104> 和 template class Test<DP104> 将 Test 类实例化为支持 SP104 和 DP104 自定义类型的版本。 注意,由于我们使用了模板类,因此必须在 test.cpp 文件实例化 Test 类,否则编译器无生成正确的代码。 希望这个示例可以帮助您理解如何在 Qt 使用自定义类型。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IT1995

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值