userver: rcu::Variable< T, RcuTraits > Class Template Reference
Loading...
Searching...
No Matches
rcu::Variable< T, RcuTraits > Class Template Reference

Read-Copy-Update variable. More...

#include <userver/rcu/rcu.hpp>

Public Types

using MutexType = typename RcuTraits::MutexType
 

Public Member Functions

template<typename... Args>
 Variable (Args &&... initial_value_args)
 
template<typename... Args>
 Variable (DestructionType destruction_type, Args &&... initial_value_args)
 
 Variable (const Variable &)=delete
 
 Variable (Variable &&)=delete
 
Variableoperator= (const Variable &)=delete
 
Variableoperator= (Variable &&)=delete
 
ReadablePtr< T, RcuTraits > Read () const
 Obtain a smart pointer which can be used to read the current value.
 
ReadCopy () const
 Obtain a copy of contained value.
 
WritablePtr< T, RcuTraits > StartWrite ()
 
template<typename... Args>
WritablePtr< T, RcuTraits > StartWriteEmplace (Args &&... args)
 
void Assign (T new_value)
 Replaces the Variable's value with the provided one.
 
template<typename... Args>
void Emplace (Args &&... args)
 Replaces the Variable's value with an in-place constructed one.
 
void Cleanup ()
 

Friends

class ReadablePtr< T, RcuTraits >
 
class WritablePtr< T, RcuTraits >
 

Detailed Description

template<typename T, typename RcuTraits>
class rcu::Variable< T, RcuTraits >

Read-Copy-Update variable.

See also
Based on ideas from http://www.drdobbs.com/lock-free-data-structures-with-hazard-po/184401890 with modified API.

A variable with MT-access pattern "very often reads, seldom writes". It is specially optimized for reads. On read, one obtains a ReaderPtr<T> from it and uses the obtained value as long as it wants to. On write, one obtains a WritablePtr<T> with a copy of the last version of the value, makes some changes to it, and commits the result to update current variable value (does Read-Copy-Update). Old version of the value is not freed on update, it will be eventually freed when a subsequent writer identifies that nobody works with this version.

Note
There is no way to create a "null" Variable.

Example usage:

constexpr int kOldValue = 1;
constexpr auto kOldString = "Old string";
constexpr int kNewValue = 2;
constexpr auto kNewString = "New string";
struct Data {
int x;
std::string s;
};
rcu::Variable<Data> data = Data{kOldValue, kOldString};
{
auto ro_ptr = data.Read();
// We can use ro_ptr to access data.
// At this time, neither the writer nor the other readers are not blocked
// => you can hold a smart pointer without fear of blocking other users
ASSERT_EQ(ro_ptr->x, kOldValue);
ASSERT_EQ(ro_ptr->s, kOldString);
}
{
auto ptr = data.StartWrite();
// ptr stores a copy of the latest version of the data, now we can prepare
// a new version Readers continue to access the old version of the data
// via .Read()
ptr->x = kNewValue;
ptr->s = kNewString;
// After Commit(), the next reader in Read() gets the version of the data
// we just wrote. Old readers who did Read() before Commit() continue to
// work with the old version of the data.
ptr.Commit();
}
See also
Synchronization Primitives
Examples
samples/config_service/config_service.cpp.

Definition at line 306 of file rcu.hpp.

Member Typedef Documentation

◆ MutexType

template<typename T , typename RcuTraits >
using rcu::Variable< T, RcuTraits >::MutexType = typename RcuTraits::MutexType

Definition at line 308 of file rcu.hpp.

Constructor & Destructor Documentation

◆ Variable() [1/2]

template<typename T , typename RcuTraits >
template<typename... Args>
rcu::Variable< T, RcuTraits >::Variable ( Args &&...  initial_value_args)
inline

Create a new Variable with an in-place constructed initial value. Asynchronous destruction is enabled by default.

Parameters
initial_value_argsarguments passed to the constructor of the initial value

Definition at line 315 of file rcu.hpp.

◆ Variable() [2/2]

template<typename T , typename RcuTraits >
template<typename... Args>
rcu::Variable< T, RcuTraits >::Variable ( DestructionType  destruction_type,
Args &&...  initial_value_args 
)
inline

Create a new Variable with an in-place constructed initial value.

Parameters
destruction_typecontrols whether destruction of old values should be performed asynchronously
initial_value_argsarguments passed to the constructor of the initial value

Definition at line 330 of file rcu.hpp.

◆ ~Variable()

template<typename T , typename RcuTraits >
rcu::Variable< T, RcuTraits >::~Variable ( )
inline

Definition at line 340 of file rcu.hpp.

Member Function Documentation

◆ Assign()

template<typename T , typename RcuTraits >
void rcu::Variable< T, RcuTraits >::Assign ( new_value)
inline

Replaces the Variable's value with the provided one.

Definition at line 385 of file rcu.hpp.

◆ Cleanup()

template<typename T , typename RcuTraits >
void rcu::Variable< T, RcuTraits >::Cleanup ( )
inline

Definition at line 397 of file rcu.hpp.

◆ Emplace()

template<typename T , typename RcuTraits >
template<typename... Args>
void rcu::Variable< T, RcuTraits >::Emplace ( Args &&...  args)
inline

Replaces the Variable's value with an in-place constructed one.

Definition at line 392 of file rcu.hpp.

◆ Read()

template<typename T , typename RcuTraits >
ReadablePtr< T, RcuTraits > rcu::Variable< T, RcuTraits >::Read ( ) const
inline

Obtain a smart pointer which can be used to read the current value.

Definition at line 359 of file rcu.hpp.

◆ ReadCopy()

template<typename T , typename RcuTraits >
T rcu::Variable< T, RcuTraits >::ReadCopy ( ) const
inline

Obtain a copy of contained value.

Definition at line 364 of file rcu.hpp.

◆ StartWrite()

template<typename T , typename RcuTraits >
WritablePtr< T, RcuTraits > rcu::Variable< T, RcuTraits >::StartWrite ( )
inline

Obtain a smart pointer that will copy the current value. The pointer can be used to make changes to the value and to set the Variable to the changed value.

Definition at line 372 of file rcu.hpp.

◆ StartWriteEmplace()

template<typename T , typename RcuTraits >
template<typename... Args>
WritablePtr< T, RcuTraits > rcu::Variable< T, RcuTraits >::StartWriteEmplace ( Args &&...  args)
inline

Obtain a smart pointer to a newly in-place constructed value, but does not replace the current one yet (in contrast with regular Emplace).

Definition at line 379 of file rcu.hpp.

Friends And Related Symbol Documentation

◆ ReadablePtr< T, RcuTraits >

template<typename T , typename RcuTraits >
friend class ReadablePtr< T, RcuTraits >
friend

Definition at line 538 of file rcu.hpp.

◆ WritablePtr< T, RcuTraits >

template<typename T , typename RcuTraits >
friend class WritablePtr< T, RcuTraits >
friend

Definition at line 538 of file rcu.hpp.


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