Loading...
Searching...
No Matches
ReferenceCountedObjectPtr< ObjectType > Class Template Reference

A smart-pointer class which points to a reference-counted object. More...

#include <juce_ReferenceCountedObject.h>

Public Types

using ReferencedType = ObjectType
 The class being referenced by this pointer.
 

Public Member Functions

 ReferenceCountedObjectPtr ()=default
 Creates a pointer to a null object.
 
 ReferenceCountedObjectPtr (decltype(nullptr)) noexcept
 Creates a pointer to a null object.
 
 ReferenceCountedObjectPtr (ReferencedType *refCountedObject) noexcept
 Creates a pointer to an object.
 
 ReferenceCountedObjectPtr (ReferencedType &refCountedObject) noexcept
 Creates a pointer to an object.
 
 ReferenceCountedObjectPtr (const ReferenceCountedObjectPtr &other) noexcept
 Copies another pointer.
 
 ReferenceCountedObjectPtr (ReferenceCountedObjectPtr &&other) noexcept
 Takes-over the object from another pointer.
 
template<typename Convertible >
 ReferenceCountedObjectPtr (const ReferenceCountedObjectPtr< Convertible > &other) noexcept
 Copies another pointer.
 
ReferenceCountedObjectPtroperator= (const ReferenceCountedObjectPtr &other)
 Changes this pointer to point at a different object.
 
template<typename Convertible >
ReferenceCountedObjectPtroperator= (const ReferenceCountedObjectPtr< Convertible > &other)
 Changes this pointer to point at a different object.
 
ReferenceCountedObjectPtroperator= (ReferencedType *newObject)
 Changes this pointer to point at a different object.
 
ReferenceCountedObjectPtroperator= (ReferencedType &newObject)
 Changes this pointer to point at a different object.
 
ReferenceCountedObjectPtroperator= (decltype(nullptr))
 Resets this pointer to a null pointer.
 
ReferenceCountedObjectPtroperator= (ReferenceCountedObjectPtr &&other) noexcept
 Takes-over the object from another pointer.
 
 ~ReferenceCountedObjectPtr ()
 Destructor.
 
ReferencedTypeget () const noexcept
 Returns the object that this pointer references.
 
void reset () noexcept
 Resets this object to a null pointer.
 
ReferencedTypeoperator-> () const noexcept
 
ReferencedTypeoperator* () const noexcept
 Dereferences the object that this pointer references.
 
bool operator== (decltype(nullptr)) const noexcept
 Checks whether this pointer is null.
 
bool operator!= (decltype(nullptr)) const noexcept
 Checks whether this pointer is null.
 
bool operator== (const ObjectType *other) const noexcept
 Compares two ReferenceCountedObjectPtrs.
 
bool operator== (const ReferenceCountedObjectPtr &other) const noexcept
 Compares two ReferenceCountedObjectPtrs.
 
bool operator!= (const ObjectType *other) const noexcept
 Compares two ReferenceCountedObjectPtrs.
 
bool operator!= (const ReferenceCountedObjectPtr &other) const noexcept
 Compares two ReferenceCountedObjectPtrs.
 
 operator ReferencedType * () const noexcept
 Returns the object that this pointer references.
 

Detailed Description

template<class ObjectType>
class ReferenceCountedObjectPtr< ObjectType >

A smart-pointer class which points to a reference-counted object.

The template parameter specifies the class of the object you want to point to - the easiest way to make a class reference-countable is to simply make it inherit from ReferenceCountedObject or SingleThreadedReferenceCountedObject, but if you need to, you can roll your own reference-countable class by implementing a set of methods called incReferenceCount(), decReferenceCount(), and decReferenceCountWithoutDeleting(). See ReferenceCountedObject for examples of how these methods should behave.

When using this class, you'll probably want to create a typedef to abbreviate the full templated name - e.g.

struct MyClass : public ReferenceCountedObject
{
...
}
A smart-pointer class which points to a reference-counted object.
Definition juce_ReferenceCountedObject.h:262
A base class which provides methods for reference-counting.
Definition juce_ReferenceCountedObject.h:81
See also
ReferenceCountedObject, ReferenceCountedObjectArray

Member Typedef Documentation

◆ ReferencedType

template<class ObjectType >
using ReferenceCountedObjectPtr< ObjectType >::ReferencedType = ObjectType

The class being referenced by this pointer.

Constructor & Destructor Documentation

◆ ReferenceCountedObjectPtr() [1/7]

template<class ObjectType >
ReferenceCountedObjectPtr< ObjectType >::ReferenceCountedObjectPtr ( )
default

Creates a pointer to a null object.

◆ ReferenceCountedObjectPtr() [2/7]

template<class ObjectType >
ReferenceCountedObjectPtr< ObjectType >::ReferenceCountedObjectPtr ( decltype(nullptr) )
noexcept

Creates a pointer to a null object.

◆ ReferenceCountedObjectPtr() [3/7]

template<class ObjectType >
ReferenceCountedObjectPtr< ObjectType >::ReferenceCountedObjectPtr ( ReferencedType * refCountedObject)
noexcept

Creates a pointer to an object.

This will increment the object's reference-count.

◆ ReferenceCountedObjectPtr() [4/7]

template<class ObjectType >
ReferenceCountedObjectPtr< ObjectType >::ReferenceCountedObjectPtr ( ReferencedType & refCountedObject)
noexcept

Creates a pointer to an object.

This will increment the object's reference-count.

◆ ReferenceCountedObjectPtr() [5/7]

template<class ObjectType >
ReferenceCountedObjectPtr< ObjectType >::ReferenceCountedObjectPtr ( const ReferenceCountedObjectPtr< ObjectType > & other)
noexcept

Copies another pointer.

This will increment the object's reference-count.

◆ ReferenceCountedObjectPtr() [6/7]

template<class ObjectType >
ReferenceCountedObjectPtr< ObjectType >::ReferenceCountedObjectPtr ( ReferenceCountedObjectPtr< ObjectType > && other)
noexcept

Takes-over the object from another pointer.

◆ ReferenceCountedObjectPtr() [7/7]

template<class ObjectType >
template<typename Convertible >
ReferenceCountedObjectPtr< ObjectType >::ReferenceCountedObjectPtr ( const ReferenceCountedObjectPtr< Convertible > & other)
noexcept

Copies another pointer.

This will increment the object's reference-count (if it is non-null).

◆ ~ReferenceCountedObjectPtr()

template<class ObjectType >
ReferenceCountedObjectPtr< ObjectType >::~ReferenceCountedObjectPtr ( )

Destructor.

This will decrement the object's reference-count, which will cause the object to be deleted when the ref-count hits zero.

Member Function Documentation

◆ operator=() [1/6]

template<class ObjectType >
ReferenceCountedObjectPtr & ReferenceCountedObjectPtr< ObjectType >::operator= ( const ReferenceCountedObjectPtr< ObjectType > & other)

Changes this pointer to point at a different object.

The reference count of the old object is decremented, and it might be deleted if it hits zero. The new object's count is incremented.

References ReferenceCountedObjectPtr< ObjectType >::operator=().

Referenced by ReferenceCountedObjectPtr< ObjectType >::operator=(), ReferenceCountedObjectPtr< ObjectType >::operator=(), and ReferenceCountedObjectPtr< ObjectType >::operator=().

◆ operator=() [2/6]

template<class ObjectType >
template<typename Convertible >
ReferenceCountedObjectPtr & ReferenceCountedObjectPtr< ObjectType >::operator= ( const ReferenceCountedObjectPtr< Convertible > & other)

Changes this pointer to point at a different object.

The reference count of the old object is decremented, and it might be deleted if it hits zero. The new object's count is incremented.

References ReferenceCountedObjectPtr< ObjectType >::get(), and ReferenceCountedObjectPtr< ObjectType >::operator=().

◆ operator=() [3/6]

template<class ObjectType >
ReferenceCountedObjectPtr & ReferenceCountedObjectPtr< ObjectType >::operator= ( ReferencedType * newObject)

Changes this pointer to point at a different object.

The reference count of the old object is decremented, and it might be deleted if it hits zero. The new object's count is incremented.

References ReferenceCountedObjectPtr< ObjectType >::operator=(), and ReferenceCountedObjectPtr< ObjectType >::reset().

◆ operator=() [4/6]

template<class ObjectType >
ReferenceCountedObjectPtr & ReferenceCountedObjectPtr< ObjectType >::operator= ( ReferencedType & newObject)

Changes this pointer to point at a different object.

The reference count of the old object is decremented, and it might be deleted if it hits zero. The new object's count is incremented.

◆ operator=() [5/6]

template<class ObjectType >
ReferenceCountedObjectPtr & ReferenceCountedObjectPtr< ObjectType >::operator= ( decltype(nullptr) )

Resets this pointer to a null pointer.

References ReferenceCountedObjectPtr< ObjectType >::reset().

◆ operator=() [6/6]

template<class ObjectType >
ReferenceCountedObjectPtr & ReferenceCountedObjectPtr< ObjectType >::operator= ( ReferenceCountedObjectPtr< ObjectType > && other)
noexcept

Takes-over the object from another pointer.

◆ get()

◆ reset()

template<class ObjectType >
void ReferenceCountedObjectPtr< ObjectType >::reset ( )
noexcept

◆ operator->()

template<class ObjectType >
ReferencedType * ReferenceCountedObjectPtr< ObjectType >::operator-> ( ) const
noexcept

References jassert.

◆ operator*()

template<class ObjectType >
ReferencedType & ReferenceCountedObjectPtr< ObjectType >::operator* ( ) const
noexcept

Dereferences the object that this pointer references.

The pointer returned may be null, of course.

References jassert.

◆ operator==() [1/3]

template<class ObjectType >
bool ReferenceCountedObjectPtr< ObjectType >::operator== ( decltype(nullptr) ) const
noexcept

Checks whether this pointer is null.

◆ operator!=() [1/3]

template<class ObjectType >
bool ReferenceCountedObjectPtr< ObjectType >::operator!= ( decltype(nullptr) ) const
noexcept

Checks whether this pointer is null.

◆ operator==() [2/3]

template<class ObjectType >
bool ReferenceCountedObjectPtr< ObjectType >::operator== ( const ObjectType * other) const
noexcept

Compares two ReferenceCountedObjectPtrs.

◆ operator==() [3/3]

template<class ObjectType >
bool ReferenceCountedObjectPtr< ObjectType >::operator== ( const ReferenceCountedObjectPtr< ObjectType > & other) const
noexcept

Compares two ReferenceCountedObjectPtrs.

◆ operator!=() [2/3]

template<class ObjectType >
bool ReferenceCountedObjectPtr< ObjectType >::operator!= ( const ObjectType * other) const
noexcept

Compares two ReferenceCountedObjectPtrs.

◆ operator!=() [3/3]

template<class ObjectType >
bool ReferenceCountedObjectPtr< ObjectType >::operator!= ( const ReferenceCountedObjectPtr< ObjectType > & other) const
noexcept

Compares two ReferenceCountedObjectPtrs.

◆ operator ReferencedType *()

template<class ObjectType >
ReferenceCountedObjectPtr< ObjectType >::operator ReferencedType * ( ) const
noexcept

Returns the object that this pointer references.

The pointer returned may be null, of course. Note that this methods allows the compiler to be very lenient with what it allows you to do with the pointer, it's safer to disable this by setting JUCE_STRICT_REFCOUNTEDPOINTER=1, which increased type safety and can prevent some common slip-ups.


The documentation for this class was generated from the following file:
linkedin facebook pinterest youtube rss twitter instagram facebook-blank rss-blank linkedin-blank pinterest youtube twitter instagram