自己在项目中遇到了qmap中key值需要用到结构体,对结构体里多个值进行匹配,全部成功输出才value值。
查阅大量资料,结果不尽人意,查询时总有些漏洞,不完全正确。
自己仔细研究qmap后发现,这个是一个顺序存储的容器。顾名思义,就是比较大小,小的排放在前,大的排放在后。插入与读取时,比较key值是按照2分查找法来进行的。不废话了。直接上图。
附带了一个qdbug输出的重写,请看官一起笑纳。
代码解析:我就不解析了,强调一点,QString类型用compare比较结果不是-1,0,1。只用比较0就行了。如果真的看不懂,就把注释打开,看看qdebug的输出,就明白qmap的存入和输出逻辑了。
测试代码也给你们安排上,自行领悟。
struct comkey{
QString comname;
int comgnm;
int zhanhao;
int addr;
bool operator<(const comkey&comdata2) const
{
if( this->comname.compare(comdata2.comname) <0 ||this->comname.compare(comdata2.comname) >0)
{
// qDebug()<