data:image/s3,"s3://crabby-images/6785a/6785afdfb15d6c7e91643f068b6e5aac56888c56" alt=""
Date: Tue, 14 Oct 2003 16:02:25 +0300 From: "Peter Dimov"
To: "Boost Users mailing list" Subject: Re: [Boost-users] shared_from_this Dragan Milenkovic wrote:
Hello, people,
I've been using enable_shared_from_this a LOT, mostly for implementing the Observer pattern (an object holds a list of weak pointers to it's observers).
[snip]
Also, any comments on the designs I used? Better observers?
It is hard to say; you'll need to go into more detail about the observers. If they are only notified on destruction of the observed entity, the typical shared_ptr approach is to reverse/eliminate the dependency and make the observers store weak pointers to the "observee".
For other notification scenarios, there is the usual tradeoff between polling and messaging. I prefer polling most of the time since this eliminates the need to store an observer list and makes it possible to "observe" classes that weren't specifically designed for this, but there may be a performance cost.
Well this (new) question is about observers in general, concurrent programming and C++. I believe to be making my way up the learning curve, but this seems to be a bit of problem. The proper destruction... Here is what I've been thinking. First the destruction of the subject (observee). As proposed in "Design Patterns", the subject could notify the observers about being destroyed, so the observers can handle that situation. But in my (more or less limited) experience, most often the observer is the one that controls the life-time of the subject (possibly by the means of shared_ptr). So this really presents no problem... But how to synchronize the destruction of the observer with a nofication originating from another thread? The observer's destructor would most likely perform Subject::unregister... But a call to Observer::update might have already been dispatched... The possible solutions I can think of are: 1. Make Subject::unregister have a postcodition stating that the observer will receive notifications no more (as of the moment the function returns). The words that come into my mind while thinking of possible implementations are: mutex, condition, dead-lock, inconsistency... What should the observer be allowed to do from inside the update function? Inspect only? I guess that could work... 2. Subject holds weak_ptr<Observer> and removes dead observers. I like it because of simplicity, but it (possibly) requires that Observer inherits enable_shared_from_this. In my design, the subject usualy passes a pointer to itself in the Observer::update method... Better yet - a shared_ptr, as it is more clean to compare shared pointer, especially inside the container. And how does it get shared_ptr to itself? shared_from_this() again. Is it really necessary? Although it does make the code easier to maintain. I might be wrong, but I get the impression that there is not much information on multithreading and destruction in C++. Destruction the way it is, makes C++ my language of preference. The lectures usually starts with a queue or a buffer with one mutex and one (or two) conditional variables, but it doesn't get any better. How is the queue destroyed? What about consumer which is waiting on a conditional variable? What is the common way of dealing with all this? Java-like interrupt? That's basically what I've been doing. Many thanks, Dragan Milenkovic
data:image/s3,"s3://crabby-images/d58f8/d58f8ba28252acb4d8757fce39634b9aff688286" alt=""
Hi All, I have a newbie Boost user question. I need to store a large graph and then repeatedly break it up into sub-graphs based on an algorithm. I also need to store properties about each vertex (name) and edge (how many times the edge was traversed in each direction, hence a directed graph). Currently, I am creating a directed graph to store the full data set using custom and built-in internal property maps to store the data. In addition, I created a undirected graph to store subgraphs. It too has internal property maps using vertex_index_t and edge_index_t, but they will simply reference vertexes and edges in the first (full) graph. Since there will be many of these sub-graphs, I didn't think it was a good idea to be copying data over and over. Anyone have any suggestions or see anything wrong with this approach? Thanks, -d
data:image/s3,"s3://crabby-images/d58f8/d58f8ba28252acb4d8757fce39634b9aff688286" alt=""
Actually, the undirected graphs should have internal property maps using: boost::graph_traits<MyDiGraph>::vertex_descriptor MyDiGraphVD; boost::graph_traits<MyDiGraph>::edge_descriptor MyDiGraphED David Ohlemacher wrote:
Hi All,
I have a newbie Boost user question. I need to store a large graph and then repeatedly break it up into sub-graphs based on an algorithm. I also need to store properties about each vertex (name) and edge (how many times the edge was traversed in each direction, hence a directed graph). Currently, I am creating a directed graph to store the full data set using custom and built-in internal property maps to store the data. In addition, I created a undirected graph to store subgraphs. It too has internal property maps using vertex_index_t and edge_index_t, but they will simply reference vertexes and edges in the first (full) graph. Since there will be many of these sub-graphs, I didn't think it was a good idea to be copying data over and over.
Anyone have any suggestions or see anything wrong with this approach?
Thanks, -d
_______________________________________________ Boost-users mailing list Boost-users@lists.boost.org http://lists.boost.org/mailman/listinfo.cgi/boost-users
-- David Ohlemacher BBN Technologies 127 John Clarke Rd. Middletown, RI 02878 Phone: (401)848-3542, Fax:(401)849-8611 ohlemacher at bbn dot com
participants (2)
-
David Ohlemacher
-
Dragan Milenkovic