A Discrete-Event Network Simulator
API
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
ns3::Scheduler Class Reference

Maintain the event list. More...

#include <scheduler.h>

+ Inheritance diagram for ns3::Scheduler:
+ Collaboration diagram for ns3::Scheduler:

Classes

struct  Event
struct  EventKey

Public Member Functions

virtual ~Scheduler ()=0
virtual void Insert (const Event &ev)=0
virtual bool IsEmpty (void) const =0
virtual Event PeekNext (void) const =0
virtual void Remove (const Event &ev)=0
virtual Event RemoveNext (void)=0
- Public Member Functions inherited from ns3::Object
 Object ()
virtual ~Object ()
void AggregateObject (Ptr< Object > other)
void Dispose (void)
AggregateIterator GetAggregateIterator (void) const
virtual TypeId GetInstanceTypeId (void) const
template<typename T >
Ptr< T > GetObject (void) const
template<typename T >
Ptr< T > GetObject (TypeId tid) const
void Start (void)
- Public Member Functions inherited from ns3::SimpleRefCount< Object, ObjectBase, ObjectDeleter >
 SimpleRefCount ()
 SimpleRefCount (const SimpleRefCount &o)
uint32_t GetReferenceCount (void) const
SimpleRefCountoperator= (const SimpleRefCount &o)
void Ref (void) const
void Unref (void) const
- Public Member Functions inherited from ns3::ObjectBase
virtual ~ObjectBase ()
void GetAttribute (std::string name, AttributeValue &value) const
bool GetAttributeFailSafe (std::string name, AttributeValue &attribute) const
void SetAttribute (std::string name, const AttributeValue &value)
bool SetAttributeFailSafe (std::string name, const AttributeValue &value)
bool TraceConnect (std::string name, std::string context, const CallbackBase &cb)
bool TraceConnectWithoutContext (std::string name, const CallbackBase &cb)
bool TraceDisconnect (std::string name, std::string context, const CallbackBase &cb)
bool TraceDisconnectWithoutContext (std::string name, const CallbackBase &cb)

Static Public Member Functions

static TypeId GetTypeId (void)
 This method returns the TypeId associated to ns3::Scheduler.

Additional Inherited Members

- Protected Member Functions inherited from ns3::Object
 Object (const Object &o)
virtual void DoDispose (void)
virtual void DoStart (void)
virtual void NotifyNewAggregate (void)

Detailed Description

Maintain the event list.

This base class specifies the interface used to maintain the event list. If you want to provide a new event list scheduler, you need to create a subclass of this base class and implement all the pure virtual methods defined here.

The only tricky aspect of this API is the memory management of the EventImpl pointer which is a member of the Event data structure. The lifetime of this pointer is assumed to always be longer than the lifetime of the Scheduler class which means that the caller is responsible for ensuring that this invariant holds through calling EventId::Ref and SimpleRefCount::Unref at the right time. Typically, EventId::Ref is called before Insert and SimpleRefCount::Unref is called after a call to one of the Remove methods.

Definition at line 53 of file scheduler.h.

Constructor & Destructor Documentation

ns3::Scheduler::~Scheduler ( )
pure virtual

Definition at line 28 of file scheduler.cc.

Member Function Documentation

TypeId ns3::Scheduler::GetTypeId ( void  )
static

This method returns the TypeId associated to ns3::Scheduler.

No Attributes defined for this type.
No TraceSources defined for this type.

Reimplemented from ns3::Object.

Reimplemented in ns3::CalendarScheduler, ns3::HeapScheduler, ns3::ListScheduler, and ns3::MapScheduler.

Definition at line 33 of file scheduler.cc.

References ns3::TypeId::SetParent().

+ Here is the call graph for this function:

virtual Event ns3::Scheduler::PeekNext ( void  ) const
pure virtual
Returns
a pointer to the next earliest event. The caller takes ownership of the returned pointer.

This method cannot be invoked if the list is empty.

Implemented in ns3::CalendarScheduler, ns3::HeapScheduler, ns3::ListScheduler, and ns3::MapScheduler.

Referenced by ns3::RealtimeSimulatorImpl::NextTs(), and ns3::DistributedSimulatorImpl::NextTs().

+ Here is the caller graph for this function:

virtual void ns3::Scheduler::Remove ( const Event ev)
pure virtual
Parameters
evthe event to remove

This methods cannot be invoked if the list is empty.

Implemented in ns3::CalendarScheduler, ns3::ListScheduler, and ns3::MapScheduler.

Referenced by ns3::DefaultSimulatorImpl::Remove(), ns3::RealtimeSimulatorImpl::Remove(), and ns3::DistributedSimulatorImpl::Remove().

+ Here is the caller graph for this function:


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