cesium-native 0.43.0
Loading...
Searching...
No Matches
CesiumUtility::ReferenceCounted< T, isThreadSafe > Class Template Reference

A reference-counted base class, meant to be used with IntrusivePointer. More...

#include <CesiumUtility/ReferenceCounted.h>

Inheritance diagram for CesiumUtility::ReferenceCounted< T, isThreadSafe >:
CesiumAsync::SharedAssetDepot< LoadedQuadtreeImage, CesiumGeometry::QuadtreeTileID > CesiumAsync::SharedAssetDepot< TAssetType, TAssetKey > CesiumGltfReader::GltfSharedAssetSystem CesiumRasterOverlays::RasterOverlay CesiumRasterOverlays::RasterOverlayTile CesiumRasterOverlays::RasterOverlayTileProvider Cesium3DTilesSelection::TilesetSharedAssetSystem CesiumRasterOverlays::BingMapsRasterOverlay CesiumRasterOverlays::DebugColorizeTilesRasterOverlay CesiumRasterOverlays::IonRasterOverlay CesiumRasterOverlays::RasterizedPolygonsOverlay CesiumRasterOverlays::TileMapServiceRasterOverlay CesiumRasterOverlays::WebMapServiceRasterOverlay CesiumRasterOverlays::WebMapTileServiceRasterOverlay CesiumRasterOverlays::QuadtreeRasterOverlayTileProvider

Public Member Functions

void addReference () const
 Adds a counted reference to this object. Use CesiumUtility::IntrusivePointer instead of calling this method directly.
 
void releaseReference () const
 Removes a counted reference from this object. When the last reference is removed, this method will delete this instance. Use CesiumUtility::IntrusivePointer instead of calling this method directly.
 
std::int32_t getReferenceCount () const noexcept
 Returns the current reference count of this instance.
 

Detailed Description

template<typename T, bool isThreadSafe = true>
class CesiumUtility::ReferenceCounted< T, isThreadSafe >

A reference-counted base class, meant to be used with IntrusivePointer.

Consider using ReferenceCountedThreadSafe or ReferenceCountedNonThreadSafe instead of using this class directly.

Template Parameters
TThe type that is deriving from this class. For example, you should declare your class as class MyClass : public ReferenceCounted<MyClass> { ... };
isThreadSafeIf true, the reference count will be thread-safe by using std::atomic, allowing references to safely be added and removed from any thread at any time. The object will be destroyed in the thread that releases the last reference. If false, it uses a simple integer for the reference count, which is not thread safe. In this case, references must be added and removed (including automatically via IntrusivePointer) from only one thread at a time. However, this mode has a bit less overhead for objects that are only ever accessed from a single thread.

Definition at line 50 of file ReferenceCounted.h.

Constructor & Destructor Documentation

◆ ReferenceCounted()

template<typename T , bool isThreadSafe = true>
CesiumUtility::ReferenceCounted< T, isThreadSafe >::ReferenceCounted ( )
inlinenoexcept

Definition at line 56 of file ReferenceCounted.h.

◆ ~ReferenceCounted()

template<typename T , bool isThreadSafe = true>
CesiumUtility::ReferenceCounted< T, isThreadSafe >::~ReferenceCounted ( )
inlinenoexcept

Definition at line 57 of file ReferenceCounted.h.

Member Function Documentation

◆ addReference()

template<typename T , bool isThreadSafe = true>
void CesiumUtility::ReferenceCounted< T, isThreadSafe >::addReference ( ) const
inline

Adds a counted reference to this object. Use CesiumUtility::IntrusivePointer instead of calling this method directly.

Definition at line 64 of file ReferenceCounted.h.

◆ getReferenceCount()

template<typename T , bool isThreadSafe = true>
std::int32_t CesiumUtility::ReferenceCounted< T, isThreadSafe >::getReferenceCount ( ) const
inlinenoexcept

Returns the current reference count of this instance.

Definition at line 97 of file ReferenceCounted.h.

◆ releaseReference()

template<typename T , bool isThreadSafe = true>
void CesiumUtility::ReferenceCounted< T, isThreadSafe >::releaseReference ( ) const
inline

Removes a counted reference from this object. When the last reference is removed, this method will delete this instance. Use CesiumUtility::IntrusivePointer instead of calling this method directly.

Definition at line 80 of file ReferenceCounted.h.


The documentation for this class was generated from the following file: