Rogue Wave banner
Previous fileTop of DocumentContentsIndex pageNext file
Threads Module Reference Guide
Rogue Wave web site:  Home Page  |  Main Documentation Page

RWTPCValQueueGuarded<Type>

Module:  Threads   Package:  Interthread Communication


RWTPCValQueueGuarded<Type> RWTPCValBufferBaseGuarded<Type,RWTGuardDecorator<Type>>

Local Index

Members

Header File

#include <rw/itc/RWTPCValQueueGuarded.h> 

Description

RWTPCValQueueGuarded<Type> is a first-in-first-out (FIFO) queue that provides producer-consumer synchronization semantics for exchanging guarded values between cooperating threads.

In the producer-consumer synchronization model, reader threads (consumers) are blocked while the queue is empty, and writer threads (producers) are blocked while the queue is full. The queue is considered full when the number of unread entries equals or exceeds some user-specified maximum capacity.

The write operations inherited by this class bind a guard functor to each value prior to storing that value in an internal buffer. A guard functor is used during read operations to determine whether the associated value is currently eligible for retrieval from the buffer.

Example

This code produces the following output:

Public Constructor

RWTPCValQueueGuarded(size_t maxCapacity=0, 
bool isOpen=true);

Public Destructor

~RWTPCValQueueGuarded();

See Also

RWTPCValBufferBaseGuarded<Type,GuardDecorator>, RWTPCValStackGuarded<Type>, RWTPCValQueueGuardedPrioritized<Type>



Previous fileTop of DocumentContentsIndex pageNext file

© Copyright Rogue Wave Software, Inc. All Rights Reserved.
Rogue Wave and SourcePro are registered trademarks of Rogue Wave Software, Inc. in the United States and other countries. All other trademarks are the property of their respective owners.
Contact Rogue Wave about documentation or support issues.