#include<Windows.h>
#include <iostream>
#include<fstream>
#include<vector>
#include<list>
#include<set>
#include <map>
#include <string>


using namespace std;
#define NUM1 10 //外层循环10次
#define NUM2 100000000 //对于int、dword的1亿次i++和++i
#define NUM3 100000//对与包含10万个元素容器的iter++和++iter

#ifdef _DEBUG
#define _FNAME "debug_"
#else
#define _FNAME "release_"
#endif

typedef struct _ElemType1
{
	DWORD dw;
	_ElemType1(DWORD _dw=0):dw(_dw)
	{
	}
	bool operator<(_ElemType1 const &t1) const
	{
		return this->dw<t1.dw;
	}
}ElemType1;


typedef struct _ElemType2
{
	string str;
	_ElemType2(string _str=""):str(_str)
	{

	}
	bool operator<(_ElemType2 const &t1) const
	{
		return this->str<t1.str;

	}
}ElemType2;

void test1_int_i(ofstream &of);
void test1_dword_i(ofstream &of);
void test2_vec_type1(ofstream &of);
void test2_vec_type2(ofstream &of);
void test3_list_type1(ofstream &of);
void test3_list_type2(ofstream &of);
void test4_set_type1(ofstream &of);
void test4_set_type2(ofstream &of);
void test5_map_type1(ofstream &of);
void test5_map_type2(ofstream &of);



void test1_int_i(ofstream &of)
{
	volatile int i=0,j=0;
	DWORD dw1,dw2,total=0;
	cout<<"int类型:"<<endl;
	of<<"int类型:"<<endl;

	cout<<"i++测试:"<<endl;
	of<<"i++测试:"<<endl;

	for(;j<NUM1;++j)
	{
		dw1 = ::GetTickCount();
		while (i<NUM2)
		{
			i++;
		}
		dw2 = ::GetTickCount();
		i=0;
		cout<<j<<" : "<<dw2-dw1<<endl;
		of<<j<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;

	i = j = 0;
	total = 0;
	cout<<"++i测试:"<<endl;
	of<<"++i测试:"<<endl;

	for(;j<NUM1;++j)
	{
		dw1 = ::GetTickCount();
		while (i<NUM2)
		{
			++i;
		}
		dw2 = ::GetTickCount();
		i=0;
		cout<<j<<" : "<<dw2-dw1<<endl;
		of<<j<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;
}

void test1_dword_i(ofstream &of)
{
	volatile DWORD i=0,j=0;
	DWORD dw1,dw2,total=0;
	cout<<"DWORD类型:"<<endl;
	of<<"DWORD类型:"<<endl;

	cout<<"i++测试:"<<endl;
	of<<"i++测试:"<<endl;

	for(;j<NUM1;++j)
	{
		dw1 = ::GetTickCount();
		while (i<NUM2)
		{
			i++;
		}
		dw2 = ::GetTickCount();
		i=0;
		cout<<j<<" : "<<dw2-dw1<<endl;
		of<<j<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;

	i = j = 0;
	total = 0;
	cout<<"++i测试:"<<endl;
	of<<"++i测试:"<<endl;

	for(;j<NUM1;++j)
	{
		dw1 = ::GetTickCount();
		while (i<NUM2)
		{
			++i;
		}
		dw2 = ::GetTickCount();
		i=0;
		cout<<j<<" : "<<dw2-dw1<<endl;
		of<<j<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;

}



DWORD g_dwFlag=0;
void test2_vec_type1(ofstream &of)
{
	ElemType1 t1;
	vector<ElemType1> vec1(NUM3,t1);

	DWORD dw1,dw2,total=0;
	cout<<"vector,使用type1:"<<endl;
	of<<"vector,使用type1:"<<endl;

	cout<<"iter++测试:"<<endl;
	of<<"iter++测试:"<<endl;

	int i = 0,j=0;
	vector<ElemType1>::iterator iter;
	vector<ElemType1>::const_iterator citer;

	for(;i<NUM1;++i)
	{
		iter = vec1.begin();
		dw1 = ::GetTickCount();
		while (iter!=vec1.end())
		{

#ifdef NDEBUG
g_dwFlag+=i;
#endif


			iter++;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}

	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;

	i=0;
	total=0;

	cout<<"++iter测试:"<<endl;
	of<<"++iter测试:"<<endl;

	for(;i<NUM1;++i)
	{
		dw1 = ::GetTickCount();
		iter = vec1.begin();
		while (iter!=vec1.end())
		{
#ifdef NDEBUG
			g_dwFlag+=i;
#endif
			++iter;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;


	i=0;
	total=0;
	cout<<"citer++测试:"<<endl;
	of<<"citer++测试:"<<endl;

	for(;i<NUM1;++i)
	{
		dw1 = ::GetTickCount();
		citer = vec1.begin();
		while (citer!=vec1.end())
		{
#ifdef NDEBUG
			g_dwFlag+=i;
#endif
			citer++;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;

	i=0;
	total=0;
	cout<<"++citer测试:"<<endl;
	of<<"++citer测试:"<<endl;

	for(;i<NUM1;++i)
	{
		dw1 = ::GetTickCount();
		citer = vec1.begin();
		while (citer!=vec1.end())
		{
#ifdef NDEBUG
			g_dwFlag+=i;
#endif
			++citer;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;
}

void test2_vec_type2(ofstream &of)
{
	ElemType2 t2;

	vector<ElemType2> vec1(NUM3,t2);

	DWORD dw1,dw2,total=0;
	cout<<"vector,使用type2:"<<endl;
	of<<"vector,使用type2:"<<endl;

	cout<<"iter++测试:"<<endl;
	of<<"iter++测试:"<<endl;

	int i = 0,j=0;
	vector<ElemType2>::iterator iter;
	vector<ElemType2>::const_iterator citer;


	for(;i<NUM1;++i)
	{
		dw1 = ::GetTickCount();
		iter = vec1.begin();
		while (iter!=vec1.end())
		{
#ifdef NDEBUG
			g_dwFlag+=i;
#endif
			iter++;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;

	i=0;
	total=0;

	cout<<"++iter测试:"<<endl;
	of<<"++iter测试:"<<endl;

	for(;i<NUM1;++i)
	{
		dw1 = ::GetTickCount();
		iter = vec1.begin();
		while (iter!=vec1.end())
		{
#ifdef NDEBUG
			g_dwFlag+=i;
#endif
			++iter;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;


	i=0;
	total=0;
	cout<<"citer++测试:"<<endl;
	of<<"citer++测试:"<<endl;

	for(;i<NUM1;++i)
	{
		dw1 = ::GetTickCount();
		citer = vec1.begin();
		while (citer!=vec1.end())
		{
#ifdef NDEBUG
			g_dwFlag+=i;
#endif
			citer++;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;

	i=0;
	total=0;
	cout<<"++citer测试:"<<endl;
	of<<"++citer测试:"<<endl;

	for(;i<NUM1;++i)
	{
		dw1 = ::GetTickCount();
		citer = vec1.begin();
		while (citer!=vec1.end())
		{
#ifdef NDEBUG
			g_dwFlag+=i;
#endif
			++citer;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;
}

void test3_list_type1(ofstream &of)
{
	ElemType1 t1;
	list<ElemType1> ls(NUM3,t1);

	DWORD dw1,dw2,total=0;
	cout<<"list,使用type1:"<<endl;
	of<<"list,使用type1:"<<endl;

	cout<<"iter++测试:"<<endl;
	of<<"iter++测试:"<<endl;

	int i = 0,j=0;
	list<ElemType1>::iterator iter;
	list<ElemType1>::const_iterator citer;


	for(;i<NUM1;++i)
	{
		dw1 = ::GetTickCount();
		iter = ls.begin();
		while (iter!=ls.end())
		{
#ifdef NDEBUG
			g_dwFlag+=i;
#endif
			iter++;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;

	i=0;
	total=0;

	cout<<"++iter测试:"<<endl;
	of<<"++iter测试:"<<endl;

	for(;i<NUM1;++i)
	{
		dw1 = ::GetTickCount();
		iter = ls.begin();
		while (iter!=ls.end())
		{
#ifdef NDEBUG
			g_dwFlag+=i;
#endif
			++iter;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;


	i=0;
	total=0;
	cout<<"citer++测试:"<<endl;
	of<<"citer++测试:"<<endl;

	for(;i<NUM1;++i)
	{
		dw1 = ::GetTickCount();
		citer = ls.begin();
		while (citer!=ls.end())
		{
#ifdef NDEBUG
			g_dwFlag+=i;
#endif
			citer++;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;

	i=0;
	total=0;
	cout<<"++citer测试:"<<endl;
	of<<"++citer测试:"<<endl;

	for(;i<NUM1;++i)
	{
		dw1 = ::GetTickCount();
		citer = ls.begin();
		while (citer!=ls.end())
		{
#ifdef NDEBUG
			g_dwFlag+=i;
#endif
			++citer;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;
}

void test3_list_type2(ofstream &of)
{
	ElemType2 t2;
	list<ElemType2> ls(NUM3,t2);

	DWORD dw1,dw2,total=0;
	cout<<"list,使用type2:"<<endl;
	of<<"list,使用type2:"<<endl;

	cout<<"iter++测试:"<<endl;
	of<<"iter++测试:"<<endl;

	int i = 0,j=0;
	list<ElemType2>::iterator iter;
	list<ElemType2>::const_iterator citer;


	for(;i<NUM1;++i)
	{
		dw1 = ::GetTickCount();
		iter = ls.begin();
		while (iter!=ls.end())
		{
#ifdef NDEBUG
			g_dwFlag+=i;
#endif
			iter++;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;

	i=0;
	total=0;

	cout<<"++iter测试:"<<endl;
	of<<"++iter测试:"<<endl;

	for(;i<NUM1;++i)
	{
		dw1 = ::GetTickCount();
		iter = ls.begin();
		while (iter!=ls.end())
		{
#ifdef NDEBUG
			g_dwFlag+=i;
#endif
			++iter;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;


	i=0;
	total=0;
	cout<<"citer++测试:"<<endl;
	of<<"citer++测试:"<<endl;

	for(;i<NUM1;++i)
	{
		dw1 = ::GetTickCount();
		citer = ls.begin();
		while (citer!=ls.end())
		{
#ifdef NDEBUG
			g_dwFlag+=i;
#endif
			citer++;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;

	i=0;
	total=0;
	cout<<"++citer测试:"<<endl;
	of<<"++citer测试:"<<endl;

	for(;i<NUM1;++i)
	{
		dw1 = ::GetTickCount();
		citer = ls.begin();
		while (citer!=ls.end())
		{
#ifdef NDEBUG
			g_dwFlag+=i;
#endif
			++citer;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;
}


void test4_set_type1(ofstream &of)
{
	set<ElemType1> ls;
	for (int n=0;n<NUM3;++n)
	{
		ls.insert(_ElemType1(n));
	}

	DWORD dw1,dw2,total=0;
	cout<<"set,使用type1:"<<endl;
	of<<"set,使用type1:"<<endl;

	cout<<"iter++测试:"<<endl;
	of<<"iter++测试:"<<endl;

	int i = 0,j=0;
	set<ElemType1>::iterator iter;
	set<ElemType1>::const_iterator citer;


	for(;i<NUM1;++i)
	{
		iter = ls.begin();

		dw1 = ::GetTickCount();
		while (iter!=ls.end())
		{
			iter++;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;

	i=0;
	total=0;

	cout<<"++iter测试:"<<endl;
	of<<"++iter测试:"<<endl;

	for(;i<NUM1;++i)
	{
		iter = ls.begin();
		dw1 = ::GetTickCount();
		while (iter!=ls.end())
		{
			++iter;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;


	i=0;
	total=0;
	cout<<"citer++测试:"<<endl;
	of<<"citer++测试:"<<endl;

	for(;i<NUM1;++i)
	{
		citer = ls.begin();

		dw1 = ::GetTickCount();
		while (citer!=ls.end())
		{
			citer++;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;

	i=0;
	total=0;
	cout<<"++citer测试:"<<endl;
	of<<"++citer测试:"<<endl;

	for(;i<NUM1;++i)
	{
		citer = ls.begin();

		dw1 = ::GetTickCount();
		while (citer!=ls.end())
		{
			++citer;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;
}
void test4_set_type2(ofstream &of)
{

	set<ElemType2> ls;
	char sz[255];
	for (int n=0;n<NUM3;++n)
	{
		itoa(n,sz,10);
		ls.insert(ElemType2(sz));
	}

	DWORD dw1,dw2,total=0;
	cout<<"set,使用type2:"<<endl;
	of<<"set,使用type2:"<<endl;

	cout<<"iter++测试:"<<endl;
	of<<"iter++测试:"<<endl;

	int i = 0,j=0;
	set<ElemType2>::iterator iter;
	set<ElemType2>::const_iterator citer;


	for(;i<NUM1;++i)
	{
		iter = ls.begin();
		dw1 = ::GetTickCount();
		while (iter!=ls.end())
		{
			iter++;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;

	i=0;
	total=0;

	cout<<"++iter测试:"<<endl;
	of<<"++iter测试:"<<endl;

	for(;i<NUM1;++i)
	{
		iter = ls.begin();

		dw1 = ::GetTickCount();
		while (iter!=ls.end())
		{
			++iter;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;


	i=0;
	total=0;
	cout<<"citer++测试:"<<endl;
	of<<"citer++测试:"<<endl;

	for(;i<NUM1;++i)
	{
		citer = ls.begin();

		dw1 = ::GetTickCount();
		while (citer!=ls.end())
		{
			citer++;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;

	i=0;
	total=0;
	cout<<"++citer测试:"<<endl;
	of<<"++citer测试:"<<endl;

	for(;i<NUM1;++i)
	{
		citer = ls.begin();

		dw1 = ::GetTickCount();
		while (citer!=ls.end())
		{
			++citer;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;
}
void test5_map_type1(ofstream &of)
{
	map<int,ElemType1> ls;

	for (int n=0;n<NUM3;++n)
	{
		ls.insert(pair<int,ElemType1>(n,ElemType1(n)));
	}

	DWORD dw1,dw2,total=0;
	cout<<"map,使用type1:"<<endl;
	of<<"map,使用type1:"<<endl;

	cout<<"iter++测试:"<<endl;
	of<<"iter++测试:"<<endl;

	int i = 0,j=0;
	map<int,ElemType1>::iterator iter;
	map<int,ElemType1>::const_iterator citer;


	for(;i<NUM1;++i)
	{
		iter = ls.begin();
		dw1 = ::GetTickCount();
		while (iter!=ls.end())
		{
			iter++;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;

	i=0;
	total=0;

	cout<<"++iter测试:"<<endl;
	of<<"++iter测试:"<<endl;

	for(;i<NUM1;++i)
	{
		iter = ls.begin();

		dw1 = ::GetTickCount();
		while (iter!=ls.end())
		{
			++iter;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;


	i=0;
	total=0;
	cout<<"citer++测试:"<<endl;
	of<<"citer++测试:"<<endl;

	for(;i<NUM1;++i)
	{
		citer = ls.begin();

		dw1 = ::GetTickCount();
		while (citer!=ls.end())
		{
			citer++;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;

	i=0;
	total=0;
	cout<<"++citer测试:"<<endl;
	of<<"++citer测试:"<<endl;

	for(;i<NUM1;++i)
	{
		citer = ls.begin();

		dw1 = ::GetTickCount();
		while (citer!=ls.end())
		{
			++citer;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;

}
void test5_map_type2(ofstream &of)
{
	map<int,ElemType2> ls;

	char sz[255];
	for (int n=0;n<NUM3;++n)
	{
		itoa(n,sz,10);
		ls.insert(pair<int,ElemType2>(n,ElemType2(sz)));
	}

	DWORD dw1,dw2,total=0;
	cout<<"map,使用type2:"<<endl;
	of<<"map,使用type2:"<<endl;

	cout<<"iter++测试:"<<endl;
	of<<"iter++测试:"<<endl;

	int i = 0,j=0;
	map<int,ElemType2>::iterator iter;
	map<int,ElemType2>::const_iterator citer;


	for(;i<NUM1;++i)
	{
		iter = ls.begin();
		dw1 = ::GetTickCount();
		while (iter!=ls.end())
		{
			iter++;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;

	i=0;
	total=0;

	cout<<"++iter测试:"<<endl;
	of<<"++iter测试:"<<endl;

	for(;i<NUM1;++i)
	{
		iter = ls.begin();

		dw1 = ::GetTickCount();
		while (iter!=ls.end())
		{
			++iter;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;


	i=0;
	total=0;
	cout<<"citer++测试:"<<endl;
	of<<"citer++测试:"<<endl;

	for(;i<NUM1;++i)
	{
		citer = ls.begin();

		dw1 = ::GetTickCount();
		while (citer!=ls.end())
		{
			citer++;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;

	i=0;
	total=0;
	cout<<"++citer测试:"<<endl;
	of<<"++citer测试:"<<endl;

	for(;i<NUM1;++i)
	{
		citer = ls.begin();

		dw1 = ::GetTickCount();
		while (citer!=ls.end())
		{
			++citer;
		}
		dw2 = ::GetTickCount();

		cout<<i<<" : "<<dw2-dw1<<endl;
		of<<i<<" : "<<dw2-dw1<<endl;
		total+=dw2-dw1;
	}
	cout<<"总消耗:"<<total<<endl;
	of<<"总消耗:"<<total<<endl;
	cout<<"平均消耗:"<<float(total)/NUM1<<endl;
	of<<"平均消耗:"<<float(total)/NUM1<<endl;

	cout<<endl;
	of<<endl;
}

#define LOGFILE_PATH_A L"qin_nkl_23529303.etl"
int main()
{
	string strFileName = _FNAME;
	string strTime = __TIME__;
	for(int k=0;k<strTime.length();++k)
		if(strTime[k]==':')
			strTime[k]='-';
	strFileName+=strTime;
	strFileName+="_test1.txt";

	//文件测试用
	char sz[MAX_PATH];
	sprintf(sz,"F:\\parse_%s_%d.txt",LOGFILE_PATH_A,GetTickCount());
	cout<<sz<<endl;

	sprintf(sz,"F:\\parse_%S_%d.txt",LOGFILE_PATH_A,GetTickCount());
	cout<<sz<<endl;

	cin.get();
	return 0;

	//strFileName = sz;
	ofstream of(strFileName.c_str());

	of<<GetTickCount()<<endl;
	of.flush();
	of.close();
	cin.get();
	return 0;

	test1_int_i(of);
	test1_dword_i(of);
	test2_vec_type1(of);
	test2_vec_type2(of);
	test3_list_type1(of);
	test3_list_type2(of);
	test4_set_type1(of);
	test4_set_type2(of);
	test5_map_type1(of);
	test5_map_type2(of);


	cout<<"标记:"<<g_dwFlag<<endl;
	of.flush();
	of.close();
	cin.get();
	return 0;
}



vector/list/set/map 遍历耗时统计的更多相关文章

  1. map遍历的四种方式

    原文 http://blog.csdn.net/dayanxuqun/article/details/26348277 以下是map遍历的四种方式: // 一.推荐只用value的时候用,都懂的... ...

  2. java map遍历方式及效率

    本文转载自Java Map遍历方式的选择. 只给出遍历方式及结论.测试数据可以去原文看. 如果你使用HashMap 同时遍历key和value时,keySet与entrySet方法的性能差异取决于ke ...

  3. 分页查询和分页缓存查询,List<Map<String, Object>>遍历和Map遍历

    分页查询 String sql = "返回所有符合条件记录的待分页SQL语句"; int start = (page - 1) * limit + 1; int end = pag ...

  4. springMVC Aspect AOP 接口耗时统计

    在接口开发中,我们通常需要统计接口耗时,为后续接口性能做统计.在springMVC中可以用它的aop来记录日志. 1.在spring配置文件中开启AOP <!--*************** ...

  5. js中三个对数组操作的函数 indexOf()方法 filter筛选 forEach遍历 map遍历

     indexOf()方法  indexOf()方法返回在该数组中第一个找到的元素位置,如果它不存在则返回-1. 不使用indexOf时 var arr = ['apple','orange','pea ...

  6. 原生JS forEach()和map()遍历的区别以及兼容写法

    一.原生JS forEach()和map()遍历 共同点: 1.都是循环遍历数组中的每一项. 2.forEach() 和 map() 里面每一次执行匿名函数都支持3个参数:数组中的当前项item,当前 ...

  7. map遍历性能记录

    map遍历可以通过keySet或者entrySet方式. 性能上:entrySet略胜一筹,原因是keySet获取到key后再根据key去获取value,在查一遍,所以慢一些. keySet: //先 ...

  8. forEach() 和 map() 遍历

    1.forEach()   没有返回值. arr[].forEach(function(value,index,array){ //do something }) 参数:value数组中的当前项, i ...

  9. js的map遍历和array遍历

    1. array遍历: [1].forEach() forEach是ES5中操作数组的一种方法,主要功能是遍历数组.forEach方法中的function回调有三个参数:第一个参数是遍历的数组内容,第 ...

随机推荐

  1. JavaWeb学习笔记(七)—— JSP

    一.什么是JSP JSP全名是Java Server Pages,它是建立在Servlet规范之上的动态网页开发技术.在JSP文件中,HTML代码与Java代码共同存在,其中,HTML代码用来实现网页 ...

  2. PHP 备份还原 MySql 数据库

    原生 PHP 备份还原 MySql 数据库 支持 MySql,PDO 两种方式备份还原 php5.5 以上的版本建议开启pdo扩展,使用 pdo 备份还原数据 备份文件夹 db_backup.impo ...

  3. Django 中的中间件

    Django 中的中间件 Django  中间件 中间件介绍 前戏 之前在判断登录的时候使用的是装饰器的功能,通过给视图函数加装饰器来增加判断是否登录的功能.但此方法的缺点是必须给每个需要判断登录的视 ...

  4. 【算法笔记】B1026 程序运行时间

    1026 程序运行时间 (15 分) 要获得一个 C 语言程序的运行时间,常用的方法是调用头文件 time.h,其中提供了 clock() 函数,可以捕捉从程序开始运行到 clock() 被调用时所耗 ...

  5. 创建一个流(Stream)可以让Bitmap或Image保存到流里面

    创建一个流(Stream)可以让Bitmap或Image保存到流里面   http://blog.csdn.net/angxiao/article/details/7481465 写文件流       ...

  6. Codeforces - 71E 状压DP

    参考官方题解 #include<bits/stdc++.h> #define rep(i,j,k) for(register int i=j;i<=k;i++) #define rr ...

  7. ngin日志格式

    日志格式 为了更好满足分析场景,推荐采用如下log_format配置.   log_format main '$remote_addr - $remote_user [$time_local] &qu ...

  8. 解决windows10活动历史记录删除问题

    Windows10日常办公过程中系统会记录很多活动历史记录信息,我是不希望我的活动历史记录随时可以被别人查看,虽然电脑有设置密码,但是办公电脑还是习惯将历史记录删除掉,并且永远禁用windows10的 ...

  9. python学习9-生成器(转载)

    什么是生成器? 生成器的实质就是迭代器,我们能够从生成器中一个一的拿值 python中获取生成器的方式有三种: 1.通过生成器函数 2.通过生成器表达式 3.通过数据转换也可以获取生成器(某些对象执行 ...

  10. kali 安装命令类

    apt-get常用命令:update – 取回更新的软件包列表信息upgrade – 进行一次升级install – 安装新的软件包(注:软件包名称是 libc6 而非 libc6.deb)remov ...