#include "ace/pre.h"
#include "ace/Synch.h"
#include "ace/Framework_Component_T.h"
#include "ace/post.h"
Include dependency graph for Framework_Component.h:

This graph shows which files directly or indirectly include this file:

| Compounds | |
| class | ACE_Framework_Component | 
| Base class that defines a uniform interface for all managed framework components. More... | |
| class | ACE_Framework_Repository | 
| Contains all framework components used by an application. More... | |
| Defines | |
| #define | ACE_DEFAULT_FRAMEWORK_REPOSITORY_SIZE 1024 | 
A prototype mechanism that allows framework components, singletons such as ACE_Reactor, ACE_Proactor, etc, to be registered with a central repository managed by the <ACE_Object_Manager> or <ACE_Service_Config> that will handle destruction.
This technique obviates changing <ACE_Object_Manager> and <ACE_Service_Config> everytime a new framework is added. Which also means that unused framework components don't need to linked into the final application which is important for applications with stringent footprint requirements.
Framework components need only provide a static method, close_singleton() and add the ACE_REGISTER_FRAMEWORK_COMPONENT macro call to their instance() methods in order to participate. Components that don't have a close_singleton() method can also participate via template specialization of ACE_Framework_Component_T.
This design uses the External Polymorphism pattern to avoid having to derive all framework components from a common base class that has virtual methods (this is crucial to avoid unnecessary overhead), and is based on the dump debugging implementation found in <ace/Dump.h>.
| 
 | 
| 
 | 
 1.2.13.1 written by Dimitri van Heesch,
 © 1997-2001
1.2.13.1 written by Dimitri van Heesch,
 © 1997-2001