=====================声明==========================

本文原创,转载请明确的注明出处和作者,并保持文章的完整性(包括本声明部分)。

本文链接:http://blog.csdn.net/wlsgzl/article/details/41722939

==================================================

至于为什么会使用这么奇葩的东西……为了部落的荣耀

----------------------------------------------------------------------------------------

在结构体中使用STL的set,比使用vector等要复杂一点,感觉是因为set的存储用到了树,所以要写“<”。

上示例代码。

#include <iostream>
#include <set>

using namespace std;

struct AA 
{
	int a1;
	int a2;

	bool operator < (const AA& oDR) const
	{
		return a1<oDR.a1;
	}
};

struct NN
{
	std::set<AA> stSet;
};

int main(int argc, char* argv[])
{
	NN stN1;

	for(int i=6;i>0;i--)
	{
		AA stA;
		stA.a1=i;
		stA.a2=10*i;
		stN1.stSet.insert(stA);
	}

	std::set<AA>::iterator it=stN1.stSet.begin();
	std::set<AA>::iterator itEnd=stN1.stSet.end();

	for(;it!=itEnd;it++)
	{
		printf("vector: a1=%d,a2=%d\n",it->a1,it->a2);
	}

	printf("sizeof(NN)=%d\n",sizeof(NN));
	printf("sizeof(stN)=%d\n",sizeof(stN1));

	//////////////////////////////////////////////////////////////////////////
	NN stN2;
	stN2.stSet=stN1.stSet;
	stN1.stSet.clear();

	it=stN2.stSet.begin();
	itEnd=stN2.stSet.end();

	for(;it!=itEnd;it++)
	{
		printf("vector: a1=%d,a2=%d\n",it->a1,it->a2);
	}

	printf("sizeof(NN)=%d\n",sizeof(NN));
	printf("sizeof(stN)=%d\n",sizeof(stN2));

	printf("http://blog.csdn.net/wlsgzl/article/details/41722939");

	return 0;
}

=====================分割线跟你说再见=======================