]>
git.saurik.com Git - wxWidgets.git/blob - interface/wx/weakref.h
   1 ///////////////////////////////////////////////////////////////////////////// 
   3 // Purpose:     interface of wxWeakRefDynamic<T>, wxWeakRef<T> 
   4 // Author:      wxWidgets team 
   6 // Licence:     wxWindows licence 
   7 ///////////////////////////////////////////////////////////////////////////// 
  11     wxWeakRefDynamic<T> is a template class for weak references that is used in 
  12     the same way as wxWeakRef<T>. The only difference is that wxWeakRefDynamic 
  13     defaults to using @c dynamic_cast for establishing the object reference 
  14     (while wxWeakRef defaults to @c static_cast). 
  16     So, wxWeakRef will detect a type mismatch during compile time and will 
  17     have a little better run-time performance. The role of wxWeakRefDynamic 
  18     is to handle objects which derived type one does not know. 
  20     @note wxWeakRef<T> selects an implementation based on the static type of T. 
  21           If T does not have wxTrackable statically, it defaults to a mixed- 
  22           mode operation, where it uses @c dynamic_cast as the last measure 
  23           (if available from the compiler and enabled when building wxWidgets). 
  25     For general cases, wxWeakRef<T> is the better choice. 
  27     For API documentation, see: wxWeakRef<T>. 
  30         The type to which the smart pointer points to. 
  33     @category{smartpointers} 
  36 class wxWeakRefDynamic
<T
> 
  45     wxWeakRef<T> is a template class for weak references to wxWidgets objects, 
  46     such as wxEvtHandler, wxWindow and wxObject. 
  47     A weak reference behaves much like an ordinary pointer, but when the object 
  48     pointed is destroyed, the weak reference is automatically reset to a @NULL pointer. 
  50     wxWeakRef<T> can be used whenever one must keep a pointer to an object 
  51     that one does not directly own, and that may be destroyed before the object 
  52     holding the reference. 
  54     wxWeakRef<T> is a small object and the mechanism behind it is fast 
  55     (@b O(1)). So the overall cost of using it is small. 
  60     wxWindow *wnd = new wxWindow( parent, wxID_ANY, "wxWindow" ); 
  61     wxWeakRef<wxWindow> wr = wnd; 
  62     wxWindowRef wr2 = wnd;        // Same as above, but using a typedef 
  63     // Do things with window 
  65     // Weak ref is used like an ordinary pointer 
  68     // Now the weak ref has been reset, so we don't risk accessing 
  69     // a dangling pointer: 
  73     wxWeakRef<T> works for any objects that are derived from wxTrackable. 
  74     By default, wxEvtHandler and wxWindow derive from wxTrackable. 
  75     However, wxObject does not, so types like wxFont and wxColour are not 
  76     trackable. The example below shows how to create a wxObject derived class 
  80     class wxMyTrackableObject : public wxObject, public wxTrackable 
  82         // ... other members here 
  86     The following types of weak references are predefined: 
  89     typedef wxWeakRef<wxEvtHandler>  wxEvtHandlerRef; 
  90     typedef wxWeakRef<wxWindow>      wxWindowRef; 
  94         The type to which the smart pointer points to. 
  97     @category{smartpointers} 
  99     @see wxSharedPtr<T>, wxScopedPtr<T> 
 102 class wxWeakRef
<T
> : public wxTrackerNode
 
 105     /// Type of the element stored by this reference. 
 106     typedef T element_type
; 
 109         Constructor. The weak reference is initialized to @e pobj. 
 111     wxWeakRef(T
* pobj 
= NULL
); 
 116     wxWeakRef(const wxWeakRef
<T
>& wr
); 
 121     virtual ~wxWeakRef(); 
 124         Called when the tracked object is destroyed. Be default sets 
 125         internal pointer to @NULL. 
 126         You need to call this method if you override it. 
 128     virtual void OnObjectDestroy(); 
 131         Release currently tracked object and rests object reference. 
 136         Returns pointer to the tracked object or @NULL. 
 141         Release currently tracked object and start tracking the same object as 
 144     T
* operator =(wxWeakRef
<T
>& wr
); 
 147         Implicit conversion to T*. 
 148         Returns pointer to the tracked object or @NULL. 
 150     T
* operator*() const; 
 153         Returns a reference to the tracked object. 
 154         If the internal pointer is @NULL this method will cause an assert in debug mode. 
 156     T
& operator*() const; 
 159         Smart pointer member access. Returns a pointer to the tracked object. 
 160         If the internal pointer is @NULL this method will cause an assert in debug mode. 
 165         Releases the currently tracked object and starts tracking @e pobj. 
 166         A weak reference may be reset by passing @e @NULL as @e pobj. 
 168     T
* operator=(T
* pobj
);