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.
75 lines
2.3 KiB
C++
75 lines
2.3 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/thread/thread_only.hpp>
|
|
#include <boost/optional.hpp>
|
|
#include <boost/bind/bind.hpp>
|
|
#include <boost/core/lightweight_test.hpp>
|
|
|
|
using namespace boost;
|
|
using namespace boost::chrono;
|
|
|
|
struct dummy_class_tracks_deletions
|
|
{
|
|
static unsigned deletions;
|
|
|
|
dummy_class_tracks_deletions()
|
|
{
|
|
std::cout << __FILE__ << ":" << __LINE__ << boost::this_thread::get_id() << std::endl;
|
|
}
|
|
~dummy_class_tracks_deletions()
|
|
{
|
|
++deletions;
|
|
std::cout << __FILE__ << ":" << __LINE__ << boost::this_thread::get_id() << std::endl;
|
|
}
|
|
|
|
};
|
|
unsigned dummy_class_tracks_deletions::deletions=0;
|
|
|
|
|
|
optional<thread_specific_ptr<dummy_class_tracks_deletions> > optr;
|
|
//struct X
|
|
//{
|
|
// thread_specific_ptr<int> f;
|
|
//} sptr;
|
|
|
|
void other_thread()
|
|
{
|
|
|
|
std::cout << __FILE__ << ":" << __LINE__ << boost::this_thread::get_id() << std::endl;
|
|
optr = none;
|
|
std::cout << __FILE__ << ":" << __LINE__ << boost::this_thread::get_id() << std::endl;
|
|
optr = in_place();
|
|
std::cout << __FILE__ << ":" << __LINE__ << boost::this_thread::get_id() << std::endl;
|
|
BOOST_TEST(optr->get() == 0);
|
|
this_thread::sleep(posix_time::seconds(5));
|
|
BOOST_TEST(optr->get() == 0);
|
|
std::cout << __FILE__ << ":" << __LINE__ << boost::this_thread::get_id() << std::endl;
|
|
|
|
}
|
|
|
|
int main()
|
|
{
|
|
|
|
std::cout << __FILE__ << ":" << __LINE__ << boost::this_thread::get_id() << std::endl;
|
|
dummy_class_tracks_deletions * pi = new dummy_class_tracks_deletions;
|
|
std::cout << __FILE__ << ":" << __LINE__ << boost::this_thread::get_id() << std::endl;
|
|
optr = in_place();
|
|
std::cout << __FILE__ << ":" << __LINE__ << boost::this_thread::get_id() << std::endl;
|
|
optr->reset(pi);
|
|
std::cout << __FILE__ << ":" << __LINE__ << boost::this_thread::get_id() << std::endl;
|
|
BOOST_TEST(optr->get() == pi);
|
|
thread t1(bind(&other_thread));
|
|
this_thread::sleep(posix_time::seconds(5));
|
|
std::cout << __FILE__ << ":" << __LINE__ << boost::this_thread::get_id() << std::endl;
|
|
BOOST_TEST(optr->get() == pi);
|
|
std::cout << __FILE__ << ":" << __LINE__ << boost::this_thread::get_id() << std::endl;
|
|
t1.join();
|
|
return boost::report_errors();
|
|
|
|
}
|