PLCnext API Documentation 25.9.0.13
Public Types | Public Member Functions | List of all members
Arp::Base::Core::IEnumerator< T > Class Template Referenceabstract

Declares the interface of the enumerator pattern, which is leaned on .NET enumerator idiom. More...

#include <IEnumerator.hxx>

Inheritance diagram for Arp::Base::Core::IEnumerator< T >:
Inheritance graph

Public Types

using Ptr = std::shared_ptr< IEnumerator >
 The smart pointer type of this interface.
 
using ValueType = T
 Type of the enumerated values
 

Public Member Functions

 IEnumerator (void)=default
 Constructs an IEnumerator instance.
 
 IEnumerator (const IEnumerator &arg)=default
 Deleted copy constructor.
 
 IEnumerator (IEnumerator &&arg) noexcept=default
 Move constructor.
 
IEnumeratoroperator= (const IEnumerator &arg)=default
 Deleted copy-assignment IEnumerator.
 
IEnumeratoroperator= (IEnumerator &&arg) noexcept=default
 Move-assignment operator.
 
virtual ~IEnumerator (void)=default
 Destructs this instance and frees all resources.
 
virtual bool MoveNext (void)=0
 Moves this enumerator to the next position. More...
 
virtual T GetCurrent (void)=0
 Gets the element at the current position. More...
 

Detailed Description

template<class T>
class Arp::Base::Core::IEnumerator< T >

Declares the interface of the enumerator pattern, which is leaned on .NET enumerator idiom.

Template Parameters
TThe element type of the container or collection, respectively.

The enumerator pattern is more easy to implement and to use, because the C++ iterator idiom always requires two arguments (begin, end) when defining algorithms or other operations working on containers or collections.

There is one big difference between iterators and enumerators: When a begin iterator is created it points to the first position of the container/collection immediately. In contrast the enumerator has to be moved once after creation before accessing the first element of a container/collection. Thus, iterators are mostly used with for loops (or range based for loops), but enumerators should always be used with while loops as shown in the following example:

IEnumerator<Any> e = GetAnyEnumerator();
while(e.MoveNext())
{
// do anything with e.GetCurrent()
}
Declares the interface of the enumerator pattern, which is leaned on .NET enumerator idiom.
Definition: IEnumerator.hxx:49
virtual bool MoveNext(void)=0
Moves this enumerator to the next position.

This interface might also be used with a reference type or even const reference type as template parameter, e.g.

IEnumerator<Any&> e = GetAnyRefEnumerator();
while(e.MoveNext())
{
Any& item = e.GetCurrent(); // no copy of e.Current
}
IEnumerator<const Any&> e = GetAnyConstRefEnumerator();
while(e.MoveNext())
{
const Any& item = e.GetCurrent(); // no copy of e.Current, item is not mutable
}
virtual T GetCurrent(void)=0
Gets the element at the current position.
@ Any
An unspecified Socket error has occurred.

Member Function Documentation

◆ GetCurrent()

template<class T >
virtual T Arp::Base::Core::IEnumerator< T >::GetCurrent ( void  )
pure virtual

◆ MoveNext()

template<class T >
virtual bool Arp::Base::Core::IEnumerator< T >::MoveNext ( void  )
pure virtual

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