Tervel
1.0.0
A collection of wait-free containers and algorithms.
|
#include <pushbackwra_op.h>
Public Member Functions | |
PushWRAOp (Vector< T > *vec, T val) | |
~PushWRAOp () | |
void | help_complete () |
Implementations of this function that upon its return the operation described in the OpRecord has been completed. More... | |
uint64_t | result () |
Public Member Functions inherited from tervel::util::OpRecord | |
OpRecord () | |
bool | on_watch (std::atomic< void * > *address, void *expected) |
This function is used to achieve a strong watch on an Element. More... | |
bool | on_is_watched () |
This function is used to check a strong watch on an Element. More... | |
void | on_unwatch () |
This function is used to remove a strong watch on an Element. More... | |
Public Member Functions inherited from tervel::util::memory::hp::Element | |
Element () | |
virtual | ~Element () |
void | safe_delete (bool no_check=false, ElementList *const element_list=tervel::tl_thread_info->get_hp_element_list()) |
This function is used to free a hazard pointer protected object if it is safe to do so OR add it to a list to be freed later. More... | |
Private Attributes | |
Vector< T > * | vec_ |
T | new_val_ |
std::atomic< PushWRAOpHelper< T > * > | helper_ {nullptr} |
Friends | |
class | PushWRAOpHelper< T > |
|
inline |
|
inline |
|
inlinevirtual |
Implementations of this function that upon its return the operation described in the OpRecord has been completed.
As such it must be thread-safe and the extending class must contain all the information necessary to complete the operation.
Implements tervel::util::OpRecord.
|
inline |
|
friend |
|
private |
|
private |
|
private |