Qt對(duì)象模型
信號(hào)和槽、對(duì)象屬性系統(tǒng)、事件和事件過濾器、國際化翻譯機(jī)制、定時(shí)器驅(qū)動(dòng)、守衛(wèi)指針(QPoint)、動(dòng)態(tài)的對(duì)象轉(zhuǎn)換機(jī)制(dynamic cast)
信號(hào)和槽
signals:聲明一個(gè)信號(hào)使用signals,在signals前面不能使用public、private和protected等限定符,因?yàn)橹挥卸x該信號(hào)的類和其子類能發(fā)射該信號(hào)
需要繼承自QObject或其子類
在類聲明最開始處添加Q_OBJECT
槽中的參數(shù)要和信號(hào)的參數(shù)類型相對(duì)應(yīng),不能比信號(hào)參數(shù)多。
信號(hào)只用聲明,沒有定義
容器類
容器類可以用來存儲(chǔ)指定類型的項(xiàng)目,例如需要一個(gè)QString類型的可變大小的數(shù)組,那么可以使用QVector(QString)。
Qt提供了順序容器(QList 、QLinkedList 、QVector、QStack、QQueue)關(guān)聯(lián)容器(QMap、QMultiMap、QHash、QMultiHash和QSet),這些容器存儲(chǔ)的是<鍵,值>,比如QMap<Key,T>。
QList<T>,目前最常用的容器類,他存儲(chǔ)了給定類型的一個(gè)列表,而這些值可以通過索引訪問。在內(nèi)部,QList使用數(shù)組來實(shí)現(xiàn),以確保進(jìn)行快速的基于索引的訪問。
QList::append() QList::prepend()
在列表倆端添加項(xiàng)目QList::insert()
在列表的中間插入項(xiàng)目。
QLinkedList<T>除了使用迭代器而不使用整數(shù)索引訪問項(xiàng)目外,它基本與QList相同,當(dāng)在一個(gè)很大列表中間插入項(xiàng)目其性能表現(xiàn)的更好。
QVector<T>它在內(nèi)存相鄰位置存儲(chǔ)給定類型的值得一個(gè)數(shù)組,在vector中間插入項(xiàng)目是非常緩慢。
QStack<T>它是QVector一個(gè)便捷子類,提供了后進(jìn)先出的語義,添加了push()、pop()、top()等函數(shù)
QQueue<T>它是QVector的便捷子類,通過了先進(jìn)先出的語義,添加了enqueue()、dequeue()、和head()等函數(shù)
QMap<Key,T>它提供了一個(gè)字典,將Key類型的鍵值映射到T類型的值上,一般一個(gè)鍵關(guān)聯(lián)一個(gè)值,QMap使用鍵順序來存儲(chǔ)他們,如果不關(guān)心順序可以使用QHash來代替他
QMultiMap<Key,T>是QMap的一個(gè)便捷類,提供了多值映射的方便接口函數(shù)
QList
//插入項(xiàng)目
QList<QString> list; list << "aa" << "bb" << "cc"; list[3] = "ab"; list.append("dd"); list.prepend("mm"); list.insert(2,"mm");
//替換項(xiàng)目,交換項(xiàng)目
list.replace(2,"bc"); list.swap(1,3);
//刪除項(xiàng)目
QString str = list.takeAt(2);
//包含項(xiàng)目,包含個(gè)數(shù)
list.contains("mm"); list.count("mm");
//查找項(xiàng)目,指定查找位置
list.indexOf("mm");//第一個(gè)“mm”的位置 list.indexOf("mm",1); list.at(i);
QMap
//插入項(xiàng)目
QMap<QString,int> map; map["one"] = 1; map.insert("seven",7);
//獲取鍵的值
int value1 = map["six"];
//如果map中沒有該鍵自動(dòng)插入
int values = map.value("five");//不會(huì)自動(dòng)插入
//一鍵多值
map.insertMulti("two",2); map.insertMulti("two",4); QList<int> values = map.values("two");
遍歷容器
遍歷一個(gè)容器可以使用迭代器來完成,迭代器提供了一個(gè)統(tǒng)一的方法來訪問容器中的項(xiàng)目。Qt提供了二種風(fēng)格的迭代器:Java風(fēng)格迭代器和STL風(fēng)格迭代器。按順序遍歷一遍容器中項(xiàng)目還可以使用Qt的foreach關(guān)鍵字
Java風(fēng)格迭代器
容器 只讀迭代器 讀/寫迭代器
QList<T> QListIterator<T> QMutableListIterator<T>
QLinkedList QLinkedListIterator<T> QMutableListIterator<T>
QListIterator<QString> i(list); //創(chuàng)建列表的只讀迭代器 while(i.hasNext()) qDebug() << i.next(); while(i.hasPrevious()) qDebug() << i.previous();
-
toFront()
將迭代器移動(dòng)到列表最前面 -
toBack()
將迭代器移動(dòng)到列表最后面 -
hasNext()
如果跌倒器沒有到達(dá)列表最后面返回true -
next()
返回下一個(gè)項(xiàng)目,并且使前移一個(gè)位置 -
peekNext()
返回下一個(gè)項(xiàng)目,但是不移動(dòng)迭代器 -
hasPrevious()
如果迭代器沒有到達(dá)最前面,那么返回true -
previous()
返回前一個(gè)項(xiàng)目,并且使迭代器前移一個(gè)位置 -
peekPrevious()
返回前一個(gè)項(xiàng)目,但是不移動(dòng)迭代器
QMutableListIterator
這個(gè)類增加了insert(),remove(),setValue,來完成插入,刪除,設(shè)置值
-
remove()
刪除上一次跳過的項(xiàng)目 -
insert()
在迭代器指向的位置插入一個(gè)項(xiàng)目,迭代器會(huì)位于添加的項(xiàng)目之后 -
setValue()
對(duì)上一次跳過的項(xiàng)目進(jìn)行賦值,也可以使用next(),previous()進(jìn)行賦值,因?yàn)檫@二個(gè)函數(shù)返回列表中項(xiàng)目一個(gè)非const引用。
QMapIterator QMutableMapIerator
QMapIterator<QString,QString> i(map);//創(chuàng)建只讀字典 i.findPrevious("xxx");向前查找鍵的值 QMutableMapIterator<QString,QString> j(map);// j.next().key().endsWith("city')
STL風(fēng)格迭代器
只讀迭代器QList<T> QList<T>::const_iterator 讀/寫迭代器QList<T>::iterator
QList<QString> list; QList<QString>::iterator i; //使用讀/寫迭代器 for(i = list.begin(); i != list.end(); ++i) { *i = (*i).toLower(); qDebug() << *i; } while(i != list.begin()){ --i; }
QList<QString>::const_iterator j; for(j = list.constBegin(); j != list.constEnd(); ++j) qDebug() << *j;
- *i 返回當(dāng)前項(xiàng)目
- ++i 前移迭代器到下一個(gè)項(xiàng)目
- i+=n 使迭代器前移n個(gè)項(xiàng)目
- --i 使迭代器往回移動(dòng)一個(gè)項(xiàng)目
- i -= n使迭代器回移n個(gè)項(xiàng)目
- i - j 返回迭代器i和迭代器j之間的項(xiàng)目的數(shù)目
foreach
QList<QString> list;
foreach(QString str, list){
qDebug() << str;
}
QMap<QString,int> map;
foreach(QString str,map.keys){
qDebug() << str << ":" << map.valus(str);
}
通用算法
在<QtAlgorithms>頭文件中,Qt提供了一些全局的模板函數(shù),這些函數(shù)可以使用在容器上的十分常用的算法。可以在任何提供了STL風(fēng)格迭代器的容器類上使用這些算法,如果在目標(biāo)平臺(tái)上可以使用STL,那么可以使用STL算法來代替這些算法。
QStringList list;
QVector<QString> vect(3);
qCopy(list.begin(),list.end(),vect.begin());//qCopy算法,list中項(xiàng)目復(fù)制到vect中
bool ret1 = qEqual(list.begin(),list.end(),vect.begin());//qEqual算法,list的開始到結(jié)束的所有項(xiàng)目與vect的開始及其后面的等數(shù)量項(xiàng)目進(jìn)行比較
QList<QString>::iterator i = qFind(list.begin(),list.begin(),"two");
qDebug() << *i;//從list中查找"two",返回第一個(gè)對(duì)應(yīng)值得迭代器,如果沒有找到返回end()
qFill(list.begin(),list.end(),"eleven");//將list中所有項(xiàng)目填充為eleven
int coutOf6 = 0;
qCount(list1.begin(),list1.end(),6,coutOf6);//查找6的個(gè)數(shù)
//返回第一個(gè)出現(xiàn)5的位置,如果沒有返回5應(yīng)該在的位置
//list1被查找的范圍中項(xiàng)目必須是升序
QList<int>::iterator j = qLowerBound(list1.begin(),list1.end(),5);
list1.insert(j,5);
qStableSort(list2.begin(),list2.end());//比較穩(wěn)定的排序算法,還有一種是qSort()
qDebug() << list2;
qSort(list2.begin(),list2.end(),qGreater<int>());//qGreater()可以在qSort()算法中使其反向排序
qSwap(pi,e);//交換pi和e的值
QString
編輯操作
QString str = "hello"; qDebug() << QObject::tr("字符串大小:") << str.size(); str[0] = QChar('H'); str.append(" Qt");//向字符串添加Qt str.replace(1,4,"i");//將第1個(gè)字符串開始的后面4個(gè)字符串替換為字符串“i” str.insert(2," my");//在第二個(gè)字符串后插入" my" str += str + "!!!"; str = " hi\r\n Qt! \n "; QString str1 = str.trimmed(); //去除字符串二端空白字符 QString str2 = str.simplified();//去除字符串倆端和中間多余空白字符 QStringList list = str.split(",",QString::SkipEmptyParts);//將字符串中有“,”的地方將其分割為多個(gè)子字符串,SkipEmptyParts表示跳過空項(xiàng)目 str = list.join(" ");//將各個(gè)子字符串合為一個(gè)字符串,中間用“ ”隔開 QString("").isEmpty();
查詢操作
str.right(5);//包含右側(cè)5個(gè)字符的子字符串 str.left(5);//包含左側(cè)5個(gè)字符的子字符串 str.mid(2,3)//包含第二個(gè)字符以后3個(gè)字符的子字符串 str.indexOf("fei");//fei的位置 str.count('i');//str中i的個(gè)數(shù) str.startsWith("ya");//str是否以ya開始 str.endsWith("lll")//str是否以lll結(jié)尾 str.contains("lin")//str是否包含lin
轉(zhuǎn)換操作
str = "100"; str.toInt();//結(jié)果為100 int num = 45; QString::number(num);//結(jié)果為“45” QString::number(num,16);//結(jié)果為45的16進(jìn)制顯示 str = "FF"; bool ok; int hex = str.toInt(&ok,16);//結(jié)果為ok: true 255 num = 26; QString::number(num,16); str = "123.456"; str.toFloat();//結(jié)果為123.456 str = "abc"; str.toUpper();//結(jié)果為ABC str = "ABC"; str.toLower();//結(jié)果為abc int age = 22; QString name = "sss"; str = QStrign("name is %1,age iss %2").arg(name).arg(age);// str = "%1 %2"; qDebug() << str.arg(" %1f","hello");//結(jié)果為%1f hell0 qDebug() << str.arg(" %1f").arg("hello");//結(jié)果為hellof %2 str = QString("ni%1").arg("hi",5,'*');//結(jié)果為ni***hi,如果是-5nihi*** qreal value = 123.456; str = QString("number:%1").arg(value,0,'f',2);//結(jié)果為123,45 qPrintable(str);不會(huì)顯示引號(hào)
QByteArray和QVariant
QByteArray提供了一個(gè)字節(jié)數(shù)組,可以用來存儲(chǔ)原始字節(jié)(包括‘\0’),和傳統(tǒng)的以‘\0’結(jié)尾的8位字符串