一直想知道C++的STL中list在加入一个元素的时候是加了对象的一个copy或说复制还是所就把那个对象给加到链表中去了,google了很久,可惜似乎大家不关心呀,今天见老师的时候老师说你自己写个例子跑跑看,可不就是呀,我居然没有想到自己去验证,比较的失败,实验一下终于有了结果(在代码里),测试代码如下:
#include<iostream>
#include<list>
using namespace std;
class myclass{
public:
int b;
int *a;
myclass(int *aa,int ab)
{
a=aa;
b=ab;
};
void output()
{
cout<<"i am "<<a<<"and "<<b<<endl;
};
};
int main()
{
//下面的测试证明STL中的list在将对象push到链表的时候使用的是复制对象的方法,
//从test.output()输出的结果(i am 003B5F58and 12)可以看出,由于是复制对象,而list删除的只是test对象的一个副本,
//所以myclass中的a指针指向的内容被释放掉了(因为副本和test指向的是同一块内存区域),但是b不是指针,
//所以在output的时候,b是存在的,但是a指向的内存被释放掉了
int *testint=new int(10);
myclass test(testint,12);
list<myclass> testlist;
testlist.push_back(test);
testlist.pop_back();
test.output();
int a;
cin>>a;
return 1;
}