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 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
|
/* -*- c++ -*- */
// $Id: Reaper.h 93678 2011-03-29 12:38:46Z johnnyw $
#ifndef JAWS_REAPER_H
#define JAWS_REAPER_H
#include "ace/Singleton.h"
#if !defined (ACE_LACKS_PRAGMA_ONCE)
# pragma once
#endif /* ACE_LACKS_PRAGMA_ONCE */
#include "ace/Task.h"
#include "ace/Synch_Traits.h"
#include "JAWS/Export.h"
// A reaper class to reap the threads.
class JAWS_Concurrency_Base;
/**
* Reap threads for the concurrency strategies
*
* The JAWS_Reaper uses the default Thread Manager (while each
* concurrency strategy uses their own). The idea is that the
* reaper will spawn a thread to reap the threads of a concurrency
* strategy. This allows the main thread to reap the threads of
* the reaper before exiting.
*/
class JAWS_Export JAWS_Reaper : public ACE_Task<ACE_SYNCH>
{
public:
JAWS_Reaper (JAWS_Concurrency_Base *concurrency);
virtual ~JAWS_Reaper (void);
virtual int open (void * = 0);
virtual int svc (void);
private:
JAWS_Concurrency_Base *concurrency_;
int waiting_;
ACE_SYNCH_MUTEX lock_;
};
#endif /* JAWS_REAPER_H */
|