c ++的执行顺序

时间:2015-06-24 17:39:09

标签: c++ carchive

我创建了一个测试carchive的程序。我想看看节省一百万个数据点所需的速度有多快:

#include "stdafx.h"
#include "TestData.h"
#include <iostream>
#include <vector>

using namespace std;

void pause() {
    cin.clear();
    cout << endl << "Press any key to continue...";
    cin.ignore();
}

int _tmain(int argc, _TCHAR* argv[])
{
    int numOfPoint = 1000000;

    printf("Starting test...\n\n");
    vector<TestData>* dataPoints = new vector<TestData>();

    printf("Creating %i points...\n", numOfPoint);
    for (int i = 0; i < numOfPoint; i++)
    {
        TestData* dataPoint = new TestData();
        dataPoints->push_back(*dataPoint);
    }
    printf("Finished creating points.\n\n");

    printf("Creating archive...\n");
    CFile* pFile = new CFile();
    CFileException e;
    TCHAR* fileName = _T("foo.dat");
    ASSERT(pFile != NULL);
    if (!pFile->Open(fileName, CFile::modeCreate | CFile::modeReadWrite | CFile::shareExclusive, &e))
    {
        return -1;
    }

    bool bReading = false;
    CArchive* pArchive = NULL;
    try
    {
        pFile->SeekToBegin();
        UINT uMode = (bReading ? CArchive::load : CArchive::store);
        pArchive = new CArchive(pFile, uMode);
        ASSERT(pArchive != NULL);
    }
    catch (CException* pException)
    {
        return -2;
    }
    printf("Finished creating archive.\n\n");

    //SERIALIZING DATA
    printf("Serializing data...\n");
    for (int i = 0; i < dataPoints->size(); i++)
    {
        dataPoints->at(i).serialize(pArchive);
    }
    printf("Finished serializing data.\n\n");

    printf("Cleaning up...\n");
    pArchive->Close();
    delete pArchive;
    pFile->Close();
    delete pFile;
    printf("Finished cleaning up.\n\n");

    printf("Test Complete.\n");

    pause();

    return 0;
}

当我运行此代码时,创建数据点需要一些时间,但几乎可以立即运行其余代码。但是,我必须等待大约4分钟才能使应用程序真正完成运行。我假设应用程序会在序列化数据部分等待,就像在创建数据点时一样。

所以我的问题是这实际上是如何运作的。 carchive是否在单独的线程上执行其操作并允许其余代码执行?

如有必要,我可以提供更多信息。

1 个答案:

答案 0 :(得分:4)

如果你想创建一个带有百万个元素的向量,这些元素都是默认初始化的,你只需要使用这个版本的构造函数

vector<TestData> dataPoints{numOfPoint};

你应该停止new所有事情,让RAII为你处理清理工作。

另外,如果push_back的容量不够大,请知道resize需要reserve向量,所以如果你从一个空向量开始,并知道它有多大最后,您可以提前使用vector<TestData> dataPoints; dataPoints.reserve(numOfPoint); for (int i = 0; i < numOfPoint; i++) { dataPoints->push_back(TestData{}); }

/home/GENERAL_POOL/