一直想知道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;}