RE: Bug in g++ 2.96

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



What do you get if you fill and delete the vector before the set?  In
other words, if you do it the other way around?  As mentioned by someone
else, memory fragmentation can be an issue, since a vector wants a
contiguous block of memory, whereas a set doesn't care.

Cheers,
Lyle


-----Original Message-----
From: Michael Mwangi [mailto:mwangi@xxxxxxxxxxxxxxxxxxxxx] 
Sent: Saturday, October 11, 2003 9:26 PM
To: Momchil Velikov
Cc: bug-g++@xxxxxxx; gcc-help@xxxxxxx
Subject: Re: Bug in g++ 2.96

> >>>>> "Michael" == Michael Mwangi <mwangi@xxxxxxxxxxxxxxxxxxxxx>
writes:
> 
>     Michael> Using top, I monitored memory usage and noticed the
>     Michael> delete operation did not free the 24 MB allocated by the
> 
>   That simply means that the memory is not returned to the kernel.
> Nevertheless, it is still available for allocation by the same process
> and is eventually returned to the kernel when the process exits.
> 
> ~velco


Thank-you very much for your quick response. I need but ask one more 
question for clarification. A set containing a 1000000 longs and a 
vector containing 6000000 longs each take about 24 MB. Consider
the following two programs:

#include <set>
int main()
{
     set<unsigned long> *s1 = new set<unsigned long>();
     set<unsigned long> *s2 = new set<unsigned long>();
     unsigned long i;

     for(i = 1; i <= 1000000; i++)
     {
          (*s1).insert(i);
     }
     (*s1).clear();
     delete s1;
     for(i = 1; i <= 1000000; i++)
     {
          (*s2).insert(i);
     }
     while(1);
}

#include <set>
#include <vector>
int main()
{
     set<unsigned long> *s1 = new set<unsigned long>();
     vector<unsigned long> *v1 = new vector<unsigned long>();
     unsigned long i;

     for(i = 1; i <= 1000000; i++)
     {
          (*s1).insert(i);
     }
     (*s1).clear();
     delete s1;
     for(i = 1; i <= 6000000; i++)
     {
          (*v1).push_back(i);
     }
     while(1);
}

When I compiled and ran the first program and monitored memory usage
using 
top, I as I expected observed that the program in total used 24 MB.
Hence, 
it appears that the 24MB allocated for the first set are made available 
by de-allocation using delete for the second set. The second program 
however uses in total 48 MB. Hence, the 24 MB allocated for the set is
not made available using delete for the subsequent vector. You stated 
above: 

"That simply means that the memory is not returned to the kernel. 
Nevertheless, it is still available for allocation by the same 
process."

In this context, the same process are operations on the set class.
Operations on the vector class constitute a different process. Thus,
if you allocate a large amount of memory in a program for a set
and the delete the set, it will not be avaliable for anything else
but filling another set. If all subsequent operations involve 
objects of classes other than set, the memory is essential lost 
to your program. Am I right, or is there a way around this?

Mike





[Index of Archives]     [Linux C Programming]     [Linux Kernel]     [eCos]     [Fedora Development]     [Fedora Announce]     [Autoconf]     [The DWARVES Debugging Tools]     [Yosemite Campsites]     [Yosemite News]     [Linux GCC]

  Powered by Linux