aboutsummaryrefslogtreecommitdiff
path: root/works/life/operating-system-experiment/MutexAvoidDataRaceDemo.cpp
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2021-06-10 11:35:29 +0800
committercrupest <crupest@outlook.com>2021-06-10 11:35:29 +0800
commitf532667d936500f50447d63333544f603ec06137 (patch)
treeab04f5afa2448e82baa82e409d5eb3fa6910a468 /works/life/operating-system-experiment/MutexAvoidDataRaceDemo.cpp
parentef593ba2d445af515214d63bfd3942be9d673467 (diff)
downloadcrupest-f532667d936500f50447d63333544f603ec06137.tar.gz
crupest-f532667d936500f50447d63333544f603ec06137.tar.bz2
crupest-f532667d936500f50447d63333544f603ec06137.zip
import(life): ...
Diffstat (limited to 'works/life/operating-system-experiment/MutexAvoidDataRaceDemo.cpp')
-rw-r--r--works/life/operating-system-experiment/MutexAvoidDataRaceDemo.cpp42
1 files changed, 42 insertions, 0 deletions
diff --git a/works/life/operating-system-experiment/MutexAvoidDataRaceDemo.cpp b/works/life/operating-system-experiment/MutexAvoidDataRaceDemo.cpp
new file mode 100644
index 0000000..81a7aa1
--- /dev/null
+++ b/works/life/operating-system-experiment/MutexAvoidDataRaceDemo.cpp
@@ -0,0 +1,42 @@
+#include "Mutex.h"
+#include "Thread.h"
+
+#include <iostream>
+
+int main() {
+
+ unsigned data = 0;
+ cru::Mutex mutex;
+ mutex.Lock();
+
+ cru::Thread t1([&data, &mutex] {
+ for (int i = 0; i < 100000; i++) {
+ mutex.Lock();
+ data += 10;
+ //std::cout << "Data is now: " << data << '\n';
+ mutex.Unlock();
+ }
+ });
+
+ cru::Thread t2([&data, &mutex] {
+ for (int i = 0; i < 100000; i++) {
+ mutex.Lock();
+ data += 10;
+ //std::cout << "Data is now: " << data << '\n';
+ mutex.Unlock();
+ }
+ });
+
+ std::cout << "Created thread: " << t1.GetNativeID() << '\n';
+ std::cout << "Created thread: " << t2.GetNativeID() << '\n';
+
+ mutex.Unlock();
+
+ t1.Join();
+ t2.Join();
+
+ std::cout << "Answer is " << data << ", which is "
+ << (data == 2000000 ? "correct" : "false") << '\n';
+
+ return 0;
+}