|
|
Home » U++ Library support » U++ Core » Ptr improve
Re: Ptr improve [message #32537 is a reply to message #32528] |
Tue, 24 May 2011 09:25   |
cbpporter
Messages: 1428 Registered: September 2007
|
Ultimate Contributor |
|
|
mirek wrote on Mon, 23 May 2011 23:37 |
cbpporter wrote on Mon, 23 May 2011 07:52 | Here is an idea that has been going around in my head for a while: what if we combine the U++ way with GC.
GC is great, but the cost of mark & sweep can be to much for some cases.
Traditional memory management is problematic, and we have a relatively big cost of allocation/deallocation.
|
Well, that is relative, average allocation/deallocation is about pretty fast in U++.... (about the same as link/unlink in double-linked list + a couple of simple loads)
Quote: |
With the U++ we have everything belongs somewhere.
|
GC is quite incompatible with the concept of destructors.
Quote: |
But what if we kept the principle intact for non heap allocated objects, but for heap allocated one, the destructor would only mark the object for deletion, and it would actually get deleted latter.
|
IMO results in unmaintainable mess.
Besides, GC AFAIK is still not a part of C++. And you cannot realistically add it by library - the best you can do is stochastic approach (Boehm), which works fine, unless you are processing white noise 
Still, what is unclear to my is why to complicate your code with heap if you do not have to? The whole mission of U++ is to eliminate universal shared heap as much as possible.
Mirek
|
Destructors are not generally incompatible with GC, just the normal GC scenarios and implementation we have now. What I am proposing is reversing the order of the GC flow.
Another additional advantage would be that it would eliminate one of the big disadvantages of conservative GC: false positives and inability to deal with extremely large heaps or data that looks like pointers.
With what I am proposing, only objects whose destructors have been called will be collected, or those that were marked by the API. It is not GC, it is the U++ memory management flow, with one single difference: data is not deleted immediately. It is delayed.
This would apply to all containers that allocate memory, so it is not about eliminating universal shared heap or not so it wouldn't contrast with our mission statement.
|
|
|
Re: Ptr improve [message #32553 is a reply to message #32537] |
Tue, 24 May 2011 17:46   |
 |
mirek
Messages: 14271 Registered: November 2005
|
Ultimate Member |
|
|
cbpporter wrote on Tue, 24 May 2011 03:25 |
mirek wrote on Mon, 23 May 2011 23:37 |
cbpporter wrote on Mon, 23 May 2011 07:52 | Here is an idea that has been going around in my head for a while: what if we combine the U++ way with GC.
GC is great, but the cost of mark & sweep can be to much for some cases.
Traditional memory management is problematic, and we have a relatively big cost of allocation/deallocation.
|
Well, that is relative, average allocation/deallocation is about pretty fast in U++.... (about the same as link/unlink in double-linked list + a couple of simple loads)
Quote: |
With the U++ we have everything belongs somewhere.
|
GC is quite incompatible with the concept of destructors.
Quote: |
But what if we kept the principle intact for non heap allocated objects, but for heap allocated one, the destructor would only mark the object for deletion, and it would actually get deleted latter.
|
IMO results in unmaintainable mess.
Besides, GC AFAIK is still not a part of C++. And you cannot realistically add it by library - the best you can do is stochastic approach (Boehm), which works fine, unless you are processing white noise 
Still, what is unclear to my is why to complicate your code with heap if you do not have to? The whole mission of U++ is to eliminate universal shared heap as much as possible.
Mirek
|
Destructors are not generally incompatible with GC, just the normal GC scenarios and implementation we have now. What I am proposing is reversing the order of the GC flow.
Another additional advantage would be that it would eliminate one of the big disadvantages of conservative GC: false positives and inability to deal with extremely large heaps or data that looks like pointers.
With what I am proposing, only objects whose destructors have been called will be collected, or those that were marked by the API. It is not GC, it is the U++ memory management flow, with one single difference: data is not deleted immediately. It is delayed.
This would apply to all containers that allocate memory, so it is not about eliminating universal shared heap or not so it wouldn't contrast with our mission statement.
|
Well, very unlikely to happen, but for the fun of theoretical debate:
How do you plan to implement GC? are you going to write your C++ compiler? How would it handle typical C++ inconsistencies like pointer casts
In the past, I was experimenting with such library based GC approach, where only specific objects were subjects of GC. I was able to get it working, and it was quite optimal, however the whole thing collapsed the moment you have started mixing such objects and regular ones. I have not found a way out. Since then I consider the whole point of GC in C++ moot - perhaps Boehm or is good for fixing leaky code, but my conclusion is that you can either have reliable destructors or GC. There is nothing in between.
Mirek
|
|
|
|
|
Re: Ptr improve [message #32567 is a reply to message #32403] |
Wed, 25 May 2011 09:34   |
mr_ped
Messages: 826 Registered: November 2005 Location: Czech Republic - Praha
|
Experienced Contributor |
|
|
"I am wondering if we could get a best of both worlds"
The problem with me is, that I don't see anything good about GC, except that you can be careless about where are your data.
As most of the SW task is to manipulate data, I don't find that idea attractive at all, I prefer to know exactly what my data do and where they sit and why. From there I never really wished for GC, gives me goosebumps to never know exactly when the memory is freed.
edit:
"What I want is to delay the free operation"
and why?? What's the advantage? I see plenty of problems with it, but no single advantage.
[Updated on: Wed, 25 May 2011 09:36] Report message to a moderator
|
|
|
Re: Ptr improve [message #32569 is a reply to message #32567] |
Wed, 25 May 2011 10:27   |
 |
kohait00
Messages: 939 Registered: July 2009 Location: Germany
|
Experienced Contributor |
|
|
the strong typed nature of C++ and especially U++ leaves you with a lot of control and responsibility. imho constructing object without care (like it is in C#) is both easy and wasting performance, inviting for careless handling with ressources. knowing what's up and needed is best practice to keep apps reactive. beeing that said, i go along with mr_pen & mirek.
this does not mean that Shared<> is just bad per se. it is merley a helper. but seeing it as an invitation to go GC is a bit too far i think. as mirek said, GC is compiler support. either have it or dont. there is no safe way in between.
some more info about shared_ptr usage, which clearly shows that it brings a lot of hassle as well. hassle one can spare when investing the thinking power in a correct model. a lot of work to save work is cumbersome.
http://www.codeproject.com/KB/stl/boostsmartptr.aspx#Example : Using shared_ptr in containers
[Updated on: Wed, 25 May 2011 10:28] Report message to a moderator
|
|
|
|
|
|
|
Goto Forum:
Current Time: Fri Oct 24 13:15:09 CEST 2025
Total time taken to generate the page: 0.13504 seconds
|
|
|