当前位置: 代码迷 >> 综合 >> CArray,CMap,CList详解
  详细解决方案

CArray,CMap,CList详解

热度:7   发布时间:2024-01-10 15:19:45.0

 

 


1.
数组--CArray
  
访问方法及效率和普通的数组一样,比普通数组强大的功能是可以改变数组的大小
    Array采用队列方式存储数据,因而其内部数据元素是以物理方式顺序排列的, 所以检索、顺序执行GetAt()等函数的速度是相当快的。但是由于每次队列长度变化后,数据都要重新申请内存、拷贝内存、释放内存,因而 Insert/Add/RemoveAt()的速度都很慢。如果你使用的数据元素尺寸相当大,而且数组的操作相当复杂,频繁使用InsertAt /SetAt/RemoveAt等,应该考虑使用CList来代替。但是如果考虑Array中存储指针而不是数据本身,效率也可以接受。
   特点:通过索引(数组下标)访问的速度很快,但是插入删除操作很慢,因为插入删除操作时,是需要移动元素的。
  
访问方法:通过索引访问,普通的数组怎么用,它就可以怎么用。

MFC数组类CArray的使用的操作详解

MFC的数组类支持的数组类似于常规数组,可以存放任何数据类型。常规数组在使用前必须将其定义成能够容纳所有可能需要的元素,即先确定大小,而MFC数组类创建的对象可以根据需要动态地增大或减小,数组的起始下标是0,而上限可以是固定的,也可以随着元素的增加而增加,数组在内存中的地址仍然是连续分配的。
  MFC定义了数组模板类CArray,并针对各种常用变量类型定义了CByteArrayCArrayCUIntArrayCDArrayCStringArrayCObArrayCPtrArray

数组类