zoukankan      html  css  js  c++  java
  • map用法小例子

    一、

    Map< Key , Value > m_Eg;

    一般赋值表示成:

    TypeElem  value;

    m_Eg[key]  =  value;

    或 m_Eg.insert(make_pair(key, value));

      注:

        insert 时,若 map中已经存在该 key,则不做任何操作。

    二、 

      1、在map中,由key查找value时,首先要判断map中是否包含key。

      2、如果不检查,直接返回map[key],可能会出现意想不到的行为。如果map包含key,没有问题,如果map不包含key,使用下标有一个危险的副作用,会在map中插入一个key的元素,value取默认值,返回value。也就是说,map[key]不可能返回null。

    效果:

      

      

    三、

      场景:  

        map<int, map<CDateTime, map<string, FormulaStatus> > > m_mapFormulaStatus; //公式计算状态 
        上面的map中插入数据的地方,编译报错

    /usr/include/c++/4.8.2/bits/stl_function.h:235:20: 错误:no match for ‘operator<’ (operand types are ‘const IndicatorSys::DateTime’ and ‘const IndicatorSys::DateTime’)
    { return __x < __y; }

      原因:

        map 插入数据时会默认按 key 排序,map<int, map<CDateTime, map<string, FormulaStatus> > > m_mapFormulaStatus 中 CDateTime 结构体做 key 但是没有重载 < 运算符,所以编译报错。

      解决方法:

        CDateTime 结构体重载 < 运算符

        

  • 相关阅读:
    java关键字synchronized
    JVM调优之jstack找出最耗cpu的线程并定位代码
    高性能Mysql
    awk使用入门
    JVM性能调优监控工具
    java垃圾回收算法
    JVM内存模型
    jvm之内存分配与回收策略
    leetcode 78. 子集(c++)
    leetcode 148. 排序链表(c++)
  • 原文地址:https://www.cnblogs.com/SZxiaochun/p/6377124.html
Copyright © 2011-2022 走看看