欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

lock free

程序员文章站 2022-04-04 16:28:51
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