前言:程序中经常用到不定量数组,选择上可以使用CArray,CList,CMap,而这三者插入及遍历的效率,未测试过,随着数据量越来越大,需要做程序上的优化,于是比较下三种类型的插入盒遍历的效率。

一、测试环境

 1、测试使用的笔记本的配置。

 

 

  2 系统版本:

 

 

 二、测试数据

   自定义结构体,包含12个float的数据,准备插入1000000个数据

struct LXYDATA
{
float L;
float x;
float y;
float Tc;
float X;
float Y;
float Z;
float u;
float v;
float L1;
float a;
float b;
};

 

三 CArray测试

1 变量定义

   

CArray<LXYDATA,LXYDATA&> arrayData;

 

2 未事先指定元素个数时测试代码

LXYDATA data;
DWORD timeStart;
DWORD timeEnd;
CString strTemp;

data.L = 45.22;
data.x = 45.22;
data.y = 45.22;
data.Tc = 45.22;
data.X = 45.22;
data.Y = 45.22;
data.Z = 45.22;
data.u = 45.22;
data.v = 45.22;
data.L1 = 45.22;
data.a = 45.22;
data.b = 45.22;

timeStart = GetTickCount();
arrayData.RemoveAll();

for (int i = 0; i < 10000000; i ++)
{
arrayData.Add(data);
}
timeEnd = GetTickCount();
strTemp.Format("%d",timeEnd-timeStart);
AfxMessageBox(strTemp);

3 测试时间

  1 未指定大小的情况下,程序跑了935828ms,未出结果,内存一度上升到800+M

 

 

 

 

  2 插入前指定大小 测试时间

    timeStart = GetTickCount();
    arrayData.RemoveAll();
    arrayData.SetSize(10000000,10000000);
    for (int i = 0; i < 10000000; i ++)
    {
        arrayData.Add(data);
    }
    timeEnd = GetTickCount();
    strTemp.Format("%d",timeEnd-timeStart);
    AfxMessageBox(strTemp);

 

 

3 遍历时间

LXYDATA dataTemp;
    CString strTemp;
    DWORD timeStart,timeEnd;
    timeStart = GetTickCount();
    
    for (int i = 0; i < 1000000; i ++)
    {
        dataTemp = arrayData.GetAt(i);
    }
    timeEnd = GetTickCount();
    strTemp.Format("%d",timeEnd-timeStart);
    AfxMessageBox(strTemp);

 

 

四 CList测试

1 变量定义

CList<LXYDATA,LXYDATA&> listData;

2 插入代码

LXYDATA data;
    DWORD timeStart;
    DWORD timeEnd;
    CString strTemp;

    data.L = 45.22;
    data.x = 45.22;
    data.y = 45.22;
    data.Tc = 45.22;
    data.X = 45.22;
    data.Y = 45.22;
    data.Z = 45.22;
    data.u = 45.22;
    data.v = 45.22;
    data.L1 = 45.22;
    data.a = 45.22;
    data.b = 45.22;

    timeStart = GetTickCount();
    listData.RemoveAll();
    
    for (int i = 0; i < 10000000; i ++)
    {
        listData.AddTail(data);
    }
    timeEnd = GetTickCount();
    strTemp.Format("%d",timeEnd-timeStart);
    AfxMessageBox(strTemp);

3 插入时间

 

4 遍历时间

LXYDATA dataTemp;
    CString strTemp;
    DWORD timeStart,timeEnd;
    timeStart = GetTickCount();

// GetAt方式遍历时间过长
//     for (int i = 0; i < 1000000; i ++)
//     {
//         dataTemp = listData.GetAt(listData.FindIndex(i));
//     }

    POSITION pos = listData.GetHeadPosition();
    while(pos != NULL)
    {
        dataTemp = listData.GetNext(pos);
    }
    timeEnd = GetTickCount();
    strTemp.Format("%d",timeEnd-timeStart);
    AfxMessageBox(strTemp);

 

 

五 CMap时间测试

1 变量定义

CMap<int,int,LXYDATA,LXYDATA> mapData;

2 插入代码

LXYDATA data;
    DWORD timeStart;
    DWORD timeEnd;
    CString strTemp;

    data.L = 45.22;
    data.x = 45.22;
    data.y = 45.22;
    data.Tc = 45.22;
    data.X = 45.22;
    data.Y = 45.22;
    data.Z = 45.22;
    data.u = 45.22;
    data.v = 45.22;
    data.L1 = 45.22;
    data.a = 45.22;
    data.b = 45.22;

    timeStart = GetTickCount();
    mapData.RemoveAll();
    mapData.InitHashTable(1200001);  //一定要指定大小,大小设置实际使用到的1.2倍,且使用奇数
    for (int i = 0; i < 1000000; i ++)
    {
        mapData.SetAt(i,data);
    }
    timeEnd = GetTickCount();
    strTemp.Format("%d",timeEnd-timeStart);
    AfxMessageBox(strTemp);

3 插入时间

 

 

4 查询时间

LXYDATA dataTemp;
    CString strTemp;
    DWORD timeStart,timeEnd;
    timeStart = GetTickCount();

    POSITION pos = mapData.GetStartPosition();
    int i = 0;
    while(pos != NULL)
    {
        mapData.GetNextAssoc(pos,i,dataTemp);
    }
    
    timeEnd = GetTickCount();
    strTemp.Format("%d",timeEnd-timeStart);
    AfxMessageBox(strTemp);

 

 

 

六 总结

1 不管用哪一种方式,如果数据量较大,都要在使用前指定大小,这个效率是非一般的提升

2 CArray的遍历时间最短,只是相对较短,其他两个也没有太耗时间,可以算是基本持平

3 CMap插入时间最短,遍历时间最长

 

版权声明:本文为fredliu原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/fredliu/p/14877803.html