Qt
Internal/Contributor docs for the Qt SDK. <b>Note:</b> These are NOT official API docs; those are found <a href='https://doc.qt.io/'>here</a>.
Loading...
Searching...
No Matches
qsemaphore.h
Go to the documentation of this file.
1// Copyright (C) 2016 The Qt Company Ltd.
2// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR LGPL-3.0-only OR GPL-2.0-only OR GPL-3.0-only
3
4#ifndef QSEMAPHORE_H
5#define QSEMAPHORE_H
6
7#include <QtCore/qglobal.h>
8#include <QtCore/qdeadlinetimer.h>
9
10#include <chrono>
11
13
15
17class Q_CORE_EXPORT QSemaphore
18{
19public:
20 explicit QSemaphore(int n = 0);
22
23 void acquire(int n = 1);
24 bool tryAcquire(int n = 1);
25 QT_CORE_INLINE_SINCE(6, 6)
26 bool tryAcquire(int n, int timeout);
28#if QT_VERSION < QT_VERSION_CHECK(7, 0, 0)
29 template <typename Rep, typename Period>
30 bool tryAcquire(int n, std::chrono::duration<Rep, Period> timeout)
31 { return tryAcquire(n, QDeadlineTimer(timeout)); }
32#endif
33
34 void release(int n = 1);
35
36 int available() const;
37
38 // std::counting_semaphore compatibility:
39 bool try_acquire() noexcept { return tryAcquire(); }
40 template <typename Rep, typename Period>
41 bool try_acquire_for(const std::chrono::duration<Rep, Period> &timeout)
42 { return tryAcquire(1, timeout); }
43 template <typename Clock, typename Duration>
44 bool try_acquire_until(const std::chrono::time_point<Clock, Duration> &tp)
45 {
46 return try_acquire_for(tp - Clock::now());
47 }
48private:
49 Q_DISABLE_COPY(QSemaphore)
50
51 union {
53 QBasicAtomicInteger<quintptr> u;
54 QBasicAtomicInteger<quint32> u32[2];
55 QBasicAtomicInteger<quint64> u64;
56 };
57};
58
59#if QT_CORE_INLINE_IMPL_SINCE(6, 6)
60bool QSemaphore::tryAcquire(int n, int timeout)
61{
63}
64#endif
65
67{
68public:
70 QSemaphoreReleaser() = default;
72 explicit QSemaphoreReleaser(QSemaphore &sem, int n = 1) noexcept
73 : m_sem(&sem), m_n(n) {}
75 explicit QSemaphoreReleaser(QSemaphore *sem, int n = 1) noexcept
76 : m_sem(sem), m_n(n) {}
79 : m_sem(other.cancel()), m_n(other.m_n) {}
80 QT_MOVE_ASSIGNMENT_OPERATOR_IMPL_VIA_MOVE_AND_SWAP(QSemaphoreReleaser)
81
83 {
84 if (m_sem)
85 m_sem->release(m_n);
86 }
87
89 {
90 qt_ptr_swap(m_sem, other.m_sem);
91 std::swap(m_n, other.m_n);
92 }
93
94 QSemaphore *semaphore() const noexcept
95 { return m_sem; }
96
97 QSemaphore *cancel() noexcept
98 {
99 return std::exchange(m_sem, nullptr);
100 }
101
102private:
103 QSemaphore *m_sem = nullptr;
104 int m_n;
105};
106
108
109#endif // QSEMAPHORE_H
\inmodule QtCore
The QSemaphoreReleaser class provides exception-safe deferral of a QSemaphore::release() call.
Definition qsemaphore.h:67
Q_NODISCARD_CTOR QSemaphoreReleaser()=default
Default constructor.
Q_NODISCARD_CTOR QSemaphoreReleaser(QSemaphore *sem, int n=1) noexcept
Constructor.
Definition qsemaphore.h:75
~QSemaphoreReleaser()
Unless canceled, calls QSemaphore::release() with the arguments provided to the constructor,...
Definition qsemaphore.h:82
Q_NODISCARD_CTOR QSemaphoreReleaser(QSemaphoreReleaser &&other) noexcept
Move constructor.
Definition qsemaphore.h:78
QSemaphore * cancel() noexcept
Cancels this QSemaphoreReleaser such that the destructor will no longer call {semaphore()->release()}...
Definition qsemaphore.h:97
Q_NODISCARD_CTOR QSemaphoreReleaser(QSemaphore &sem, int n=1) noexcept
Constructor.
Definition qsemaphore.h:72
void swap(QSemaphoreReleaser &other) noexcept
Exchanges the responsibilities of {*this} and other.
Definition qsemaphore.h:88
QSemaphore * semaphore() const noexcept
Returns a pointer to the QSemaphore object provided to the constructor, or by the last move assignmen...
Definition qsemaphore.h:94
\inmodule QtCore
Definition qsemaphore.h:18
bool try_acquire() noexcept
Definition qsemaphore.h:39
QSemaphorePrivate * d
Definition qsemaphore.h:52
bool try_acquire_for(const std::chrono::duration< Rep, Period > &timeout)
Definition qsemaphore.h:41
QBasicAtomicInteger< quintptr > u
Definition qsemaphore.h:53
bool tryAcquire(int n=1)
Tries to acquire n resources guarded by the semaphore and returns true on success.
QBasicAtomicInteger< quint64 > u64
Definition qsemaphore.h:55
void release(int n=1)
Releases n resources guarded by the semaphore.
bool try_acquire_until(const std::chrono::time_point< Clock, Duration > &tp)
Definition qsemaphore.h:44
Combined button and popup list for selecting options.
#define Q_NODISCARD_CTOR
GLbitfield GLuint64 timeout
[4]
GLfloat n
constexpr void qt_ptr_swap(T *&lhs, T *&rhs) noexcept
Definition qswap.h:29
#define QT_REQUIRE_CONFIG(feature)
sem acquire()
sem release()
QSemaphore sem(5)
[0]
sem tryAcquire(1)
QSharedPointer< T > other(t)
[5]