PinGuard#
Fully qualified name: carb::tasking::PinGuard
Defined in carb/tasking/ITasking.h
-
class PinGuard#
Causes the currently executing TaskContext to be “pinned” to the thread it is currently running on until PinGuard is destroyed.
Appropriately handles recursive pinning. This class causes the current thread to be the only task thread that can run the current task. This is necessary in some cases where thread specificity is required (those these situations are NOT recommended for tasks): holding a mutex, or using thread-specific data, etc. Thread pinning is not efficient (the pinned thread could be running a different task causing delays for the current task to be resumed, and wakeTask() must wait to return until the pinned thread has been notified) and should therefore be avoided.