2012-04-29 18:52:25 +00:00
|
|
|
//
|
|
|
|
// RWLock.h
|
|
|
|
//
|
|
|
|
// Library: Foundation
|
|
|
|
// Package: Threading
|
|
|
|
// Module: RWLock
|
|
|
|
//
|
|
|
|
// Definition of the RWLock class.
|
|
|
|
//
|
|
|
|
// Copyright (c) 2004-2006, Applied Informatics Software Engineering GmbH.
|
|
|
|
// and Contributors.
|
|
|
|
//
|
2014-05-04 21:02:42 +02:00
|
|
|
// SPDX-License-Identifier: BSL-1.0
|
2012-04-29 18:52:25 +00:00
|
|
|
//
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef Foundation_RWLock_INCLUDED
|
|
|
|
#define Foundation_RWLock_INCLUDED
|
|
|
|
|
|
|
|
|
|
|
|
#include "Poco/Foundation.h"
|
|
|
|
#include "Poco/Exception.h"
|
|
|
|
|
|
|
|
|
|
|
|
#if defined(POCO_OS_FAMILY_WINDOWS)
|
|
|
|
#include "Poco/RWLock_WIN32.h"
|
2018-02-27 02:18:45 +01:00
|
|
|
#elif POCO_OS == POCO_OS_ANDROID
|
2012-04-29 18:52:25 +00:00
|
|
|
#include "Poco/RWLock_Android.h"
|
|
|
|
#elif defined(POCO_VXWORKS)
|
|
|
|
#include "Poco/RWLock_VX.h"
|
|
|
|
#else
|
|
|
|
#include "Poco/RWLock_POSIX.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
namespace Poco {
|
|
|
|
|
|
|
|
|
|
|
|
class ScopedRWLock;
|
|
|
|
class ScopedReadRWLock;
|
|
|
|
class ScopedWriteRWLock;
|
|
|
|
|
|
|
|
|
|
|
|
class Foundation_API RWLock: private RWLockImpl
|
|
|
|
/// A reader writer lock allows multiple concurrent
|
|
|
|
/// readers or one exclusive writer.
|
|
|
|
{
|
|
|
|
public:
|
2020-01-09 10:08:09 +01:00
|
|
|
using ScopedLock = ScopedRWLock;
|
|
|
|
using ScopedReadLock = ScopedReadRWLock;
|
|
|
|
using ScopedWriteLock = ScopedWriteRWLock;
|
2012-04-29 18:52:25 +00:00
|
|
|
|
|
|
|
RWLock();
|
|
|
|
/// Creates the Reader/Writer lock.
|
2022-07-07 17:18:20 +08:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
~RWLock();
|
|
|
|
/// Destroys the Reader/Writer lock.
|
2022-07-07 17:18:20 +08:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
void readLock();
|
|
|
|
/// Acquires a read lock. If another thread currently holds a write lock,
|
|
|
|
/// waits until the write lock is released.
|
|
|
|
|
|
|
|
bool tryReadLock();
|
|
|
|
/// Tries to acquire a read lock. Immediately returns true if successful, or
|
|
|
|
/// false if another thread currently holds a write lock.
|
|
|
|
|
|
|
|
void writeLock();
|
2022-07-07 17:18:20 +08:00
|
|
|
/// Acquires a write lock. If one or more other threads currently hold
|
2012-04-29 18:52:25 +00:00
|
|
|
/// locks, waits until all locks are released. The results are undefined
|
|
|
|
/// if the same thread already holds a read or write lock
|
|
|
|
|
|
|
|
bool tryWriteLock();
|
|
|
|
/// Tries to acquire a write lock. Immediately returns true if successful,
|
2022-07-07 17:18:20 +08:00
|
|
|
/// or false if one or more other threads currently hold
|
2012-04-29 18:52:25 +00:00
|
|
|
/// locks. The result is undefined if the same thread already
|
|
|
|
/// holds a read or write lock.
|
|
|
|
|
|
|
|
void unlock();
|
|
|
|
/// Releases the read or write lock.
|
|
|
|
|
|
|
|
private:
|
|
|
|
RWLock(const RWLock&);
|
|
|
|
RWLock& operator = (const RWLock&);
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class Foundation_API ScopedRWLock
|
|
|
|
/// A variant of ScopedLock for reader/writer locks.
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
ScopedRWLock(RWLock& rwl, bool write = false);
|
|
|
|
~ScopedRWLock();
|
|
|
|
|
|
|
|
private:
|
|
|
|
RWLock& _rwl;
|
|
|
|
|
|
|
|
ScopedRWLock();
|
|
|
|
ScopedRWLock(const ScopedRWLock&);
|
|
|
|
ScopedRWLock& operator = (const ScopedRWLock&);
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class Foundation_API ScopedReadRWLock : public ScopedRWLock
|
|
|
|
/// A variant of ScopedLock for reader locks.
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
ScopedReadRWLock(RWLock& rwl);
|
|
|
|
~ScopedReadRWLock();
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
class Foundation_API ScopedWriteRWLock : public ScopedRWLock
|
|
|
|
/// A variant of ScopedLock for writer locks.
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
ScopedWriteRWLock(RWLock& rwl);
|
|
|
|
~ScopedWriteRWLock();
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
// inlines
|
|
|
|
//
|
|
|
|
inline void RWLock::readLock()
|
|
|
|
{
|
|
|
|
readLockImpl();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
inline bool RWLock::tryReadLock()
|
|
|
|
{
|
|
|
|
return tryReadLockImpl();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
inline void RWLock::writeLock()
|
|
|
|
{
|
|
|
|
writeLockImpl();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
inline bool RWLock::tryWriteLock()
|
|
|
|
{
|
|
|
|
return tryWriteLockImpl();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
inline void RWLock::unlock()
|
|
|
|
{
|
|
|
|
unlockImpl();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
inline ScopedRWLock::ScopedRWLock(RWLock& rwl, bool write): _rwl(rwl)
|
|
|
|
{
|
|
|
|
if (write)
|
|
|
|
_rwl.writeLock();
|
|
|
|
else
|
|
|
|
_rwl.readLock();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
inline ScopedRWLock::~ScopedRWLock()
|
|
|
|
{
|
2014-09-19 09:46:49 +02:00
|
|
|
try
|
|
|
|
{
|
|
|
|
_rwl.unlock();
|
|
|
|
}
|
|
|
|
catch (...)
|
|
|
|
{
|
|
|
|
poco_unexpected();
|
|
|
|
}
|
2012-04-29 18:52:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
inline ScopedReadRWLock::ScopedReadRWLock(RWLock& rwl): ScopedRWLock(rwl, false)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
inline ScopedReadRWLock::~ScopedReadRWLock()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
inline ScopedWriteRWLock::ScopedWriteRWLock(RWLock& rwl): ScopedRWLock(rwl, true)
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
inline ScopedWriteRWLock::~ScopedWriteRWLock()
|
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
} // namespace Poco
|
|
|
|
|
|
|
|
|
|
|
|
#endif // Foundation_RWLock_INCLUDED
|