首页 > 代码库 > boost之mutex scoped_lock
boost之mutex scoped_lock
1.boost里的互斥量类型由mutex表示。
代码示例:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 | #include <iostream> #include <string> #include <vector> #include <boost/thread.hpp> #include <boost/thread/mutex.hpp> using namespace std; using namespace boost; int main() { mutex mu; try { this_thread::sleep(posix_time::seconds(2)); mu.lock(); //锁定cout对象 cout << "Some operations" <<endl; mu.unlock(); } catch ( int ) { mu.unlock(); return 0; } } |
二.上面的代码好像似曾相识,是的,在防止内存泄露的时候采用的和上面类似的处理方式,更加简洁的方式是智能指针,类似的我们需要用智能锁改写上面的代码scoped_lock智能锁。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 | #include <iostream> #include <string> #include <vector> #include <boost/thread.hpp> #include <boost/thread/mutex.hpp> using namespace std; using namespace boost; template < typename T> class basic_atom:noncopyable { private : T n; typedef mutex mutex_t; mutex_t mu; public : basic_atom(T x = T()):n(x){} T operator++() { mutex_t::scoped_lock lock(mu); return ++n; } operator T(){ return n;} }; int main() { return 0; } |
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。