2012-04-29 18:52:25 +00:00
|
|
|
//
|
|
|
|
// ScopedLock.h
|
|
|
|
//
|
|
|
|
// Library: Foundation
|
|
|
|
// Package: Threading
|
|
|
|
// Module: Mutex
|
|
|
|
//
|
|
|
|
// Definition of the ScopedLock template 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_ScopedLock_INCLUDED
|
|
|
|
#define Foundation_ScopedLock_INCLUDED
|
|
|
|
|
|
|
|
|
|
|
|
#include "Poco/Foundation.h"
|
|
|
|
|
|
|
|
|
|
|
|
namespace Poco {
|
|
|
|
|
|
|
|
|
|
|
|
template <class M>
|
|
|
|
class ScopedLock
|
|
|
|
/// A class that simplifies thread synchronization
|
|
|
|
/// with a mutex.
|
|
|
|
/// The constructor accepts a Mutex (and optionally
|
|
|
|
/// a timeout value in milliseconds) and locks it.
|
|
|
|
/// The destructor unlocks the mutex.
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
explicit ScopedLock(M& mutex): _mutex(mutex)
|
|
|
|
{
|
|
|
|
_mutex.lock();
|
|
|
|
}
|
2022-07-07 17:18:20 +08:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
ScopedLock(M& mutex, long milliseconds): _mutex(mutex)
|
|
|
|
{
|
|
|
|
_mutex.lock(milliseconds);
|
|
|
|
}
|
2022-07-07 17:18:20 +08:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
~ScopedLock()
|
|
|
|
{
|
2014-09-19 09:46:49 +02:00
|
|
|
try
|
|
|
|
{
|
|
|
|
_mutex.unlock();
|
|
|
|
}
|
|
|
|
catch (...)
|
|
|
|
{
|
|
|
|
poco_unexpected();
|
|
|
|
}
|
2012-04-29 18:52:25 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
M& _mutex;
|
|
|
|
|
|
|
|
ScopedLock();
|
|
|
|
ScopedLock(const ScopedLock&);
|
|
|
|
ScopedLock& operator = (const ScopedLock&);
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
template <class M>
|
|
|
|
class ScopedLockWithUnlock
|
|
|
|
/// A class that simplifies thread synchronization
|
|
|
|
/// with a mutex.
|
|
|
|
/// The constructor accepts a Mutex (and optionally
|
|
|
|
/// a timeout value in milliseconds) and locks it.
|
|
|
|
/// The destructor unlocks the mutex.
|
|
|
|
/// The unlock() member function allows for manual
|
|
|
|
/// unlocking of the mutex.
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
explicit ScopedLockWithUnlock(M& mutex): _pMutex(&mutex)
|
|
|
|
{
|
2024-08-30 04:03:33 +08:00
|
|
|
poco_assert(_pMutex != nullptr);
|
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
_pMutex->lock();
|
2024-08-30 04:03:33 +08:00
|
|
|
_locked = true;
|
2012-04-29 18:52:25 +00:00
|
|
|
}
|
2022-07-07 17:18:20 +08:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
ScopedLockWithUnlock(M& mutex, long milliseconds): _pMutex(&mutex)
|
|
|
|
{
|
2024-08-30 04:03:33 +08:00
|
|
|
poco_assert(_pMutex != nullptr);
|
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
_pMutex->lock(milliseconds);
|
2024-08-30 04:03:33 +08:00
|
|
|
_locked = true;
|
2012-04-29 18:52:25 +00:00
|
|
|
}
|
2022-07-07 17:18:20 +08:00
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
~ScopedLockWithUnlock()
|
|
|
|
{
|
2014-09-19 09:46:49 +02:00
|
|
|
try
|
|
|
|
{
|
|
|
|
unlock();
|
|
|
|
}
|
|
|
|
catch (...)
|
|
|
|
{
|
|
|
|
poco_unexpected();
|
|
|
|
}
|
2012-04-29 18:52:25 +00:00
|
|
|
}
|
2022-07-07 17:18:20 +08:00
|
|
|
|
2024-08-30 04:03:33 +08:00
|
|
|
void lock()
|
|
|
|
{
|
|
|
|
poco_assert(_pMutex != nullptr);
|
|
|
|
poco_assert(_locked == false);
|
|
|
|
|
|
|
|
_pMutex->lock();
|
|
|
|
_locked = true;
|
|
|
|
}
|
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
void unlock()
|
|
|
|
{
|
2024-08-30 04:03:33 +08:00
|
|
|
if (_locked)
|
2012-04-29 18:52:25 +00:00
|
|
|
{
|
2024-08-30 04:03:33 +08:00
|
|
|
poco_assert(_pMutex != nullptr);
|
|
|
|
|
2012-04-29 18:52:25 +00:00
|
|
|
_pMutex->unlock();
|
2024-08-30 04:03:33 +08:00
|
|
|
_locked = false;
|
2012-04-29 18:52:25 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private:
|
|
|
|
M* _pMutex;
|
2024-08-30 04:03:33 +08:00
|
|
|
bool _locked = false;
|
2012-04-29 18:52:25 +00:00
|
|
|
|
|
|
|
ScopedLockWithUnlock();
|
|
|
|
ScopedLockWithUnlock(const ScopedLockWithUnlock&);
|
|
|
|
ScopedLockWithUnlock& operator = (const ScopedLockWithUnlock&);
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
} // namespace Poco
|
|
|
|
|
|
|
|
|
|
|
|
#endif // Foundation_ScopedLock_INCLUDED
|