StreamWrapperBase

class StreamWrapperBase

The base class for both IStreamWrapper and OStreamWrapper, this provides the common locking interface.

Inheritance diagram

Inheritance diagram of StreamWrapperBase

void acquire(void)

Acquires the internal lock.

User code should call this to take temporary possession of the stream and perform direct I/O operations on it, for instance to make several sequential atomic reads. You may not call any of the StreamWrapper methods while the lock is held, other than release().

Use with extreme caution! This is a very low-level, non-recursive lock. You must call acquire() only once, and you must later call release() exactly once. Failing to do so may result in a hard deadlock with no available debugging features.

void release(void)

Releases the internal lock. Must be called exactly once following a call to acquire(). See the cautions with acquire().