C++的STL中list

    技术2022-05-12  16

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


    最新回复(0)