2022-02-22 20:33:45 +08:00
|
|
|
// Copyright 2022 Memgraph Ltd.
|
2021-10-26 14:53:56 +08:00
|
|
|
//
|
|
|
|
// Use of this software is governed by the Business Source License
|
|
|
|
// included in the file licenses/BSL.txt; by using this file, you agree to be bound by the terms of the Business Source
|
|
|
|
// License, and you may not use this file except in compliance with the Business Source License.
|
|
|
|
//
|
|
|
|
// As of the Change Date specified in that file, in accordance with
|
|
|
|
// the Business Source License, use of this software will be governed
|
|
|
|
// by the Apache License, Version 2.0, included in the file
|
|
|
|
// licenses/APL.txt.
|
|
|
|
|
2017-02-19 01:03:48 +08:00
|
|
|
#include <atomic>
|
|
|
|
#include <chrono>
|
|
|
|
#include <mutex>
|
|
|
|
#include <thread>
|
|
|
|
#include <vector>
|
|
|
|
|
2019-12-09 00:04:06 +08:00
|
|
|
#include "utils/spin_lock.hpp"
|
2017-02-19 01:03:48 +08:00
|
|
|
|
|
|
|
int x = 0;
|
2022-02-22 20:33:45 +08:00
|
|
|
memgraph::utils::SpinLock lock;
|
2017-02-19 01:03:48 +08:00
|
|
|
|
|
|
|
void test_lock() {
|
|
|
|
using namespace std::literals;
|
|
|
|
|
|
|
|
{
|
2022-02-22 20:33:45 +08:00
|
|
|
std::unique_lock<memgraph::utils::SpinLock> guard(lock);
|
2017-02-19 01:03:48 +08:00
|
|
|
x++;
|
|
|
|
|
|
|
|
std::this_thread::sleep_for(25ms);
|
|
|
|
|
2021-01-21 22:47:56 +08:00
|
|
|
MG_ASSERT(x < 2,
|
|
|
|
"x always has to be less than 2 (other "
|
|
|
|
"threads shouldn't be able to change the x simultaneously");
|
2017-02-19 01:03:48 +08:00
|
|
|
x--;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
int main() {
|
2022-03-31 19:52:43 +08:00
|
|
|
static constexpr int N = 16;
|
2017-02-19 01:03:48 +08:00
|
|
|
std::vector<std::thread> threads;
|
|
|
|
|
|
|
|
for (int i = 0; i < N; ++i) threads.push_back(std::thread(test_lock));
|
|
|
|
|
2021-01-21 22:47:56 +08:00
|
|
|
for (auto &thread : threads) {
|
2017-02-19 01:03:48 +08:00
|
|
|
thread.join();
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|