|
||
A reference counting object is one which uses reference counting to track concurrent references to itself and which arranges for automatic destruction of itself when the final reference is removed. It is also an object which can be named.
A reference counting object is any object which has CObject
as its base class.
Constructing a CObject
derived type, or calling its Open()
member function, adds a reference to that object by adding one to its reference count. Calling its Close()
member function removes a reference by subtracting one from its reference count. When the last user of the object calls Close()
, the reference count becomes zero and the object is automatically destroyed.
The following drawing shows the idea.
A DLL is an example of an entity that needs to track concurrent accesses to itself as it can be accessed concurrently by
a number of threads and processes. The Kernel side class which encapsulates DLL behaviour, DLibrary
, has CObject
as a base class. The DLibrary
object exists until all users have finished with the DLL; once the last user has closed the DLL, the DLibrary
object is destroyed.
A CObject
is always part of a class hierarchy. It is a base class; an explicit CObject
type is never instantiated.
Many Kernel side objects such as threads, processes and semaphores are instances of CObject
derived classes.
An object which is intended to be referenced by a handle should derive from CObject
. Collectively, reference counting objects, object containers and object indexes provide the behaviour for generating handle-numbers.
The server side implementation of a client/server subsession uses a CObject
.
See also: