PionNetworkLibrary
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros
pion::one_to_one_scheduler Class Reference

#include <scheduler.hpp>

Inheritance diagram for pion::one_to_one_scheduler:
Collaboration diagram for pion::one_to_one_scheduler:

Classes

struct  service_pair_type
 typedef for a pair object where first is an IO service and second is a deadline timer More...
 

Public Member Functions

 one_to_one_scheduler (void)
 constructs a new one_to_one_scheduler More...
 
virtual ~one_to_one_scheduler ()
 virtual destructor More...
 
virtual boost::asio::io_service & get_io_service (void)
 returns an async I/O service used to schedule work More...
 
virtual boost::asio::io_service & get_io_service (boost::uint32_t n)
 
virtual void startup (void)
 Starts the thread scheduler (this is called automatically when necessary) More...
 
- Public Member Functions inherited from pion::multi_thread_scheduler
 multi_thread_scheduler (void)
 constructs a new multi_thread_scheduler More...
 
virtual ~multi_thread_scheduler ()
 virtual destructor More...
 
- Public Member Functions inherited from pion::scheduler
 scheduler (void)
 constructs a new scheduler More...
 
virtual ~scheduler ()
 virtual destructor More...
 
virtual void shutdown (void)
 Stops the thread scheduler (this is called automatically when the program exits) More...
 
void join (void)
 the calling thread will sleep until the scheduler has stopped More...
 
void add_active_user (void)
 
void remove_active_user (void)
 unregisters an active user with the thread scheduler More...
 
bool is_running (void) const
 returns true if the scheduler is running More...
 
void set_num_threads (const boost::uint32_t n)
 sets the number of threads to be used (these are shared by all servers) More...
 
boost::uint32_t get_num_threads (void) const
 returns the number of threads currently in use More...
 
void set_logger (logger log_ptr)
 sets the logger to be used More...
 
logger get_logger (void)
 returns the logger currently in use More...
 
virtual void post (boost::function0< void > work_func)
 
void keep_running (boost::asio::io_service &my_service, boost::asio::deadline_timer &my_timer)
 
void process_service_work (boost::asio::io_service &service)
 processes work passed to the asio service & handles uncaught exceptions More...
 

Protected Types

typedef std::vector
< boost::shared_ptr
< service_pair_type > > 
service_pool_type
 typedef for a pool of IO services More...
 
- Protected Types inherited from pion::multi_thread_scheduler
typedef std::vector
< boost::shared_ptr
< boost::thread > > 
ThreadPool
 typedef for a pool of worker threads More...
 

Protected Member Functions

virtual void stop_services (void)
 stops all services used to schedule work More...
 
virtual void finish_services (void)
 finishes all services used to schedule work More...
 
- Protected Member Functions inherited from pion::multi_thread_scheduler
virtual void stop_threads (void)
 stops all threads used to perform work More...
 
virtual void finish_threads (void)
 finishes all threads used to perform work More...
 

Protected Attributes

service_pool_type m_service_pool
 pool of IO services used to schedule work More...
 
boost::uint32_t m_next_service
 the next service to use for scheduling work More...
 
- Protected Attributes inherited from pion::multi_thread_scheduler
ThreadPool m_thread_pool
 pool of threads used to perform work More...
 
- Protected Attributes inherited from pion::scheduler
boost::mutex m_mutex
 mutex to make class thread-safe More...
 
logger m_logger
 primary logging interface used by this class More...
 
boost::condition m_no_more_active_users
 condition triggered when there are no more active users More...
 
boost::condition m_scheduler_has_stopped
 condition triggered when the scheduler has stopped More...
 
boost::uint32_t m_num_threads
 total number of worker threads in the pool More...
 
boost::uint32_t m_active_users
 the scheduler will not shutdown until there are no more active users More...
 
bool m_is_running
 true if the thread scheduler is running More...
 

Additional Inherited Members

- Static Public Member Functions inherited from pion::scheduler
static void sleep (boost::uint32_t sleep_sec, boost::uint32_t sleep_nsec)
 
template<typename ConditionType , typename LockType >
static void sleep (ConditionType &wakeup_condition, LockType &wakeup_lock, boost::uint32_t sleep_sec, boost::uint32_t sleep_nsec)
 
- Static Protected Member Functions inherited from pion::scheduler
static boost::system_time get_wakeup_time (boost::uint32_t sleep_sec, boost::uint32_t sleep_nsec)
 
- Static Protected Attributes inherited from pion::scheduler
static const boost::uint32_t DEFAULT_NUM_THREADS = 8
 default number of worker threads in the thread pool More...
 
static const boost::uint32_t NSEC_IN_SECOND = 1000000000
 number of nanoseconds in one full second (10 ^ 9) More...
 
static const boost::uint32_t MICROSEC_IN_SECOND = 1000000
 number of microseconds in one full second (10 ^ 6) More...
 
static const boost::uint32_t KEEP_RUNNING_TIMER_SECONDS = 5
 number of seconds a timer should wait for to keep the IO services running More...
 

Detailed Description

one_to_one_scheduler: uses a single IO service for each thread

Member Typedef Documentation

typedef std::vector<boost::shared_ptr<service_pair_type> > pion::one_to_one_scheduler::service_pool_type
protected

typedef for a pool of IO services

Constructor & Destructor Documentation

pion::one_to_one_scheduler::one_to_one_scheduler ( void  )
inline

constructs a new one_to_one_scheduler

virtual pion::one_to_one_scheduler::~one_to_one_scheduler ( )
inlinevirtual

virtual destructor

Member Function Documentation

virtual void pion::one_to_one_scheduler::finish_services ( void  )
inlineprotectedvirtual

finishes all services used to schedule work

Reimplemented from pion::scheduler.

virtual boost::asio::io_service& pion::one_to_one_scheduler::get_io_service ( void  )
inlinevirtual

returns an async I/O service used to schedule work

Implements pion::scheduler.

virtual boost::asio::io_service& pion::one_to_one_scheduler::get_io_service ( boost::uint32_t  n)
inlinevirtual

returns an async I/O service used to schedule work (provides direct access to avoid locking when possible)

Parameters
ninteger number representing the service object
void pion::one_to_one_scheduler::startup ( void  )
virtual
virtual void pion::one_to_one_scheduler::stop_services ( void  )
inlineprotectedvirtual

stops all services used to schedule work

Reimplemented from pion::scheduler.

Member Data Documentation

boost::uint32_t pion::one_to_one_scheduler::m_next_service
protected

the next service to use for scheduling work

service_pool_type pion::one_to_one_scheduler::m_service_pool
protected

pool of IO services used to schedule work

Referenced by startup().


The documentation for this class was generated from the following files: