qt 链表QList,QLinkedList的常见使用

QList,QLinkedList这俩个链表是qt里面常用的模板类容器,QLinkedList继承自QList.下面先说说QList.

QList类-------------------------------------------

QList,QLinkedList是一个模板类容器,它可以存储多种数据类型.与先前介绍的QString,QStringList,它的方法也非常的类似,常用有:

append()尾部插入元素

prepend()头部插入元素

insert()指定位置插入元素

replace()替换元素(QLinkedList无)

at()用下标访问元素(QLinkedList无)

removeFirst()删除第一个元素

removeLast()删除最后一个元素

removeAt()删除指定位置元素(QLinkedList无)

removeOne()删除已知元素

clear()清空链表......

cpp 复制代码
    QList<int> list;//模板类容器.

    list<<1<<2<<3<<4<<5<<6<<7<<8;
    list<<9;
    list.append(10);    //尾部添加
    list.prepend(0);    //头部添加
    list.insert(1,99);  //指定位置插入

    list.replace(5,66);//替换元素.方式1
    list[0] = 100;     //对下标进行访问.方式2
    list.at(2);        //访问下标为2的元素

    list.removeFirst(); //删除第一个元素
    list.removeLast();  //删除最后一个元素
    list.removeAt(2);   //删除指定位置元素
    list.removeOne(7);  //删除已知元素
    list.clear();       //清空链表

qt提供了QList俩种风格的迭代器,java和STL.

java风格迭代器-----------

读写迭代器QMutableListIterator<int>

.

cpp 复制代码
    QList<int> montList;
    QMutableListIterator<int> it_mrw(montList);//读写迭代器.用链表montList进行初始化.
    for(int i=0;i<12;i++){
        it_mrw.insert(i);
    }

迭代器读,方式1

从后往前读,反遍历.toBack()把迭代器定位到最后一个元素的后一个位置(不指向元素);hasPrevious()判断前一个位置是否有元素;previous()指向前一个位置(有元素).

cpp 复制代码
    for(it_mrw.toBack();it_mrw.hasPrevious();){//hasPrevious()前一个元素存在
        qDebug()<<it_mrw.previous();//前一个元素
    }

迭代器读,方式2

从前往后读,正遍历.toFront()把迭代器定位到第一个元素的前一个位置(不指向元素);hasNext()判断后一个位置是否有元素;next()指向后一个位置(有元素).

cpp 复制代码
    for(it_mrw.toFront();it_mrw.hasNext();){//toFront()第一个元素的前一个位置
        qDebug()<<it_mrw.next();
    }

迭代器写(即对数据进行修改).

使用remove()删除元素;setValue(12)设置指定位置的值改为12;insert()插入元素......

cpp 复制代码
    for(it_mrw.toFront();it_mrw.hasNext();){//下一个元素存在

        int month = it_mrw.next();
        if(month == 0){
            it_mrw.remove();//删除
        }
        if(month == 11){
            //it_mrw.insert(88);//插入元素88
            it_mrw.setValue(12);//设置值11变为12
        }
    }

只读迭代器QListIterator<int>

cpp 复制代码
    QListIterator<int> it_mr(montList);//只读迭代器

     //正遍历
    qDebug()<<"只读迭代器正遍历:";
    for(it_mr.toFront();it_mr.hasNext();){
        qDebug()<<it_mr.next();
    }

    //反遍历
    qDebug()<<"只读迭代器反遍历:";
    for(it_mr.toBack();it_mr.hasPrevious();){//hasPrevious()上一个元素是否存在
        qDebug()<<it_mr.previous();
    }

STL风格迭代器-----------

读写迭代器QList<int>::iterator

cpp 复制代码
    QList<int> numList;
    numList<<11<<12<<23<<33<<44<<55;

    //读写迭代器
    QList<int>::iterator it_numRW;
    it_numRW = numList.begin();//返回一个迭代器.

    for(;it_numRW != numList.end();++it_numRW){
        *it_numRW = *it_numRW * 10;
        qDebug()<<*it_numRW;
    }

只读迭代器QList<int>::const_iterator

方式1

cpp 复制代码
    QList<int>::const_iterator it_numR;
    it_numR = numList.constBegin();//迭代点指向第一个元素

    //STL只读正遍历
    for(;it_numR != numList.constEnd();++it_numR){//constEnd()指向最后一个元素的下一个位置
        qDebug()<<*it_numR;
    }

方式2

cpp 复制代码
    //STL只读反遍历
    for(auto it_numR = numList.rbegin();it_numR != numList.rend();++it_numR){
        qDebug()<<*it_numR;
    }

QLindedList类-----------------------------------

QLindedList类继承自QList,与QList的区别在于,QLindedList不能使用at()和下标的方式[]访问数据,那既然QList这么好,还要QLindedList干嘛?这是因为QLinkedList处理大量数据更高效,更快速.QLinkedList也有俩种风格的迭代器.

java风格迭代器-----------

读写迭代器QMutableLinkedListIterator<QString>

cpp 复制代码
    QLinkedList<QString> weekList;//QLinkedList大量的数据处理时更具有优势
    for(int i=1;i<8;i++){
        weekList<< QString("%1%2").arg("星期").arg(i);
    }    

    QMutableLinkedListIterator<QString> it_wrw(weekList);
    for(it_wrw.toFront();it_wrw.hasNext();){

        QString day = it_wrw.next();
        if(day == "星期3"){
            it_wrw.setValue("星期三");//修改元素
        }
        if(day == "星期5"){
            it_wrw.remove();//移除元素
        }
    }


    //insert()插入元素
    for(it_wrw.toFront();it_wrw.hasNext();){
        QString day = it_wrw.next();
        if(day == "星期4"){
            it_wrw.insert("星期五");//在"星期4"后面插入"星期五"
        }
    }


    //遍历元素
    for(it_wrw.toFront();it_wrw.hasNext();){
        qDebug()<<it_wrw.next();
    }

只读迭代器QLinkedListIterator<QString>

cpp 复制代码
    for(it_wr.toFront();it_wr.hasNext();){
        qDebug()<<it_wr.next();
    }

STL风格迭代器-----------

读写迭代器QLinkedList<QString>::iterator

cpp 复制代码
    QLinkedList<QString>::iterator it_String;
    it_String = weekList.begin();

    for(;it_String != weekList.end();++it_String){

        QString w = *it_String;
        if(w== "星期1"){
            *it_String = "星期一";
        }
        //*it_String = *it_String+"星期一";
    }

    //遍历元素,读
    it_String = weekList.begin();//需重置迭代器指向最前面的位置
    for(;it_String != weekList.end();++it_String){
        qDebug()<<*it_String;
    }

只读迭代器QLinkedList<QString>::const_iterator

cpp 复制代码
    QLinkedList<QString>::const_iterator it_constStr;
    it_constStr = weekList.constBegin();

    for(;it_constStr != weekList.constEnd();++it_constStr){
        qDebug()<<*it_constStr;
    }

上面说的迭代器java,STL风格,虽然看起来说了很多,但是主要就说了

QList类的java风格的读写,只读迭代器;

QList类的STL风格的读写,只读迭代器;

QLinkedList类的java风格的读写,只读迭代器;

QLinkedList类的STL风格的读写,只读迭代器;

.

链表QList,QLinkedList的分享就到这里了~~

相关推荐
DolphinDB1 小时前
如何在C++交易系统中集成高性能回测与模拟撮合
c++
feiyangqingyun1 小时前
Qt音视频开发技巧/推流带旋转角度/rtsprtmp推流/保存文件到MP4/拉流解析旋转角度
qt·音视频·qt旋转角度推流
筏.k1 小时前
C++ 网络编程(14) asio多线程模型IOThreadPool
网络·c++·架构
清醒的兰2 小时前
Qt 基于TCP套接字编程
网络·qt·tcp
爱喝茶的小茶2 小时前
周赛98补题
开发语言·c++·算法
OpenC++2 小时前
【C++】备忘录模式
c++·设计模式·备忘录模式
小庞在加油3 小时前
《dlib库中的聚类》算法详解:从原理到实践
c++·算法·机器学习·数据挖掘·聚类
ComputerInBook3 小时前
C++ 标准模板库算法之 transform 用法
开发语言·c++·算法·transform算法
2301_803554527 小时前
c++中类的前置声明
java·开发语言·c++
LyaJpunov9 天前
深入理解 C++ volatile 与 atomic:五大用法解析 + 六大高频考点
c++·面试·volatile·atomic