mirror of
https://github.com/boostorg/thread.git
synced 2026-02-08 23:22:13 +00:00
1. Make inclusion of boost/bind/bind.hpp conditional in some cases, when the code actually conditionally uses boost::bind. Reduces compile-time overhead and fixes https://github.com/boostorg/thread/issues/307. 2. Remove some unnecessary uses of boost::ref. This allows to avoid including boost/core/ref.hpp in a few places, and avoids the associated template instantiation overhead in others. 3. Replace deprecated header includes with the more recent alternatives. For example: boost/detail/lightweight_test.hpp -> boost/core/lightweight_test.hpp, boost/ref.hpp -> boost/core/ref.hpp. 4. Replace some blanket includes with the more fine-grained ones. For example, boost/utility.hpp, boost/atomic.hpp. This reduces compile time overhead. 5. Add some missing includes, for example, boost/core/ref.hpp and boost/type_traits/is_same.hpp. 6. Replace uses of std::is_same with boost::is_same (with the corresponding included header) since the standard type_traits header presence and validity is not tested by the code. Using boost::is_same makes the code more portable.
49 lines
2.1 KiB
C++
49 lines
2.1 KiB
C++
// Copyright (C) 2010 Vicente Botet
|
|
//
|
|
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
|
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
#include <iostream>
|
|
#include <boost/thread.hpp>
|
|
#include <boost/current_function.hpp>
|
|
#include <boost/bind/bind.hpp>
|
|
|
|
class boostThreadLocksTest
|
|
{
|
|
public:
|
|
boost::shared_mutex myMutex;
|
|
//boost::upgrade_lock<boost::shared_mutex> myLock;
|
|
static int firstFunction(boostThreadLocksTest *pBoostThreadLocksTest);
|
|
static int secondFunction(boostThreadLocksTest *pBoostThreadLocksTest,
|
|
boost::upgrade_lock<boost::shared_mutex>& upgr);
|
|
boostThreadLocksTest()
|
|
:myMutex()
|
|
//, myLock(myMutex,boost::defer_lock_t())
|
|
{}
|
|
};
|
|
|
|
int boostThreadLocksTest::firstFunction(boostThreadLocksTest *pBoostThreadLocksTest)
|
|
{
|
|
std::cout<<"Entering "<<boost::this_thread::get_id()<<" "<<"firstFunction"<<std::endl;
|
|
boost::upgrade_lock<boost::shared_mutex> myLock(pBoostThreadLocksTest->myMutex);
|
|
pBoostThreadLocksTest->secondFunction(pBoostThreadLocksTest, myLock);
|
|
std::cout<<"Returned From Call "<<boost::this_thread::get_id()<<" "<<"firstFunction"<<std::endl;
|
|
std::cout<<"Returning from "<<boost::this_thread::get_id()<<" "<<"firstFunction"<<std::endl;
|
|
return(0);
|
|
}
|
|
int boostThreadLocksTest::secondFunction(boostThreadLocksTest *, boost::upgrade_lock<boost::shared_mutex>& upgr) {
|
|
std::cout<<"Before Exclusive Locking "<<boost::this_thread::get_id()<<" "<<"secondFunction"<<std::endl;
|
|
boost::upgrade_to_unique_lock<boost::shared_mutex> localUniqueLock(upgr);
|
|
std::cout<<"After Exclusive Locking "<<boost::this_thread::get_id()<<" "<<"secondFunction"<<std::endl;
|
|
return(0);
|
|
}
|
|
int main() {
|
|
boostThreadLocksTest myObject;
|
|
boost::thread_group myThreadGroup;
|
|
myThreadGroup.create_thread(boost::bind(boostThreadLocksTest::firstFunction,&myObject));
|
|
myThreadGroup.create_thread(boost::bind(boostThreadLocksTest::firstFunction,&myObject));
|
|
myThreadGroup.create_thread(boost::bind(boostThreadLocksTest::firstFunction,&myObject));
|
|
myThreadGroup.join_all();
|
|
return 0;
|
|
}
|