lock free

 1 #include <thread>
 2 #include <iostream>
 3 #include <mutex>
 4 #include <atomic>
 5 #include <chrono>
 6 
 7 using namespace std;
 8 
 9 #ifdef _LOCK_FREE
10 
11 atomic<int> i = 0;
12 
13 void foo() {
14     int count = 10000000;
15     while (count--)
16     {
17         i++;
18     }
19 }
20 
21 int main()
22 {
23     chrono::steady_clock::time_point start_time = chrono::steady_clock::now();
24 
25     thread thread1(foo);
26     thread thread2(foo);
27 
28     thread1.join();
29     thread2.join();
30 
31     cout << "i = " << i << endl;
32 
33     chrono::steady_clock::time_point end_time = chrono::steady_clock::now();
34     chrono::duration<double> time_span = chrono::duration_cast<chrono::microseconds>(end_time - start_time);
35     cout << "lock free elpased time: " << time_span.count() << " ms" << endl;
36 
37     system("pause");
38 
39     return 0;
40 }
41 #endif // _LOCK_FREE
42 
43 
44 
45 #ifdef _MUTEX_LOCK
46 int i = 0;
47 mutex g_mutex;
48 
49 
50 void foo() {
51     int count = 10000000;
52     while (count--)
53     {
54         g_mutex.lock();
55         i++;
56         g_mutex.unlock();
57     }
58 }
59 
60 int main()
61 {
62     chrono::steady_clock::time_point start_time = chrono::steady_clock::now();
63 
64     thread thread1(foo);
65     thread thread2(foo);
66 
67     thread1.join();
68     thread2.join();
69 
70     cout << "i = " << i << endl;
71 
72     chrono::steady_clock::time_point end_time = chrono::steady_clock::now();
73     chrono::duration<double> time_span = chrono::duration_cast<chrono::microseconds>(end_time - start_time);
74     cout << "mutex lock elpased time: " << time_span.count() << " ms" << endl;
75 
76     system("pause");
77 
78     return 0;
79 }
80 #endif _MUTEX_LOCK

猜你喜欢

转载自www.cnblogs.com/neverdizzy/p/9108239.html