| PLCnext API Documentation 25.6.0.37
    | 
The Acf will use this interface to start and stop components during system startup and shutdown, respectively. More...
#include <IControllerComponent.hpp>
| Public Types | |
| using | Ptr = std::shared_ptr< IControllerComponent > | 
| The pointer type of this interface. | |
| Public Member Functions | |
| virtual void | Start (void)=0 | 
| Starts this component, that is, the component starts its own threads. More... | |
| virtual void | Stop (void)=0 | 
| Stops this component, i.e. the component stops its own threads. | |
| Protected Member Functions | |
| IControllerComponent (void)=default | |
| The default constructor. | |
| IControllerComponent (IControllerComponent &&arg) noexcept=default | |
| The move constructor. More... | |
| IControllerComponent (const IControllerComponent &arg)=delete | |
| The copy constructor is deleted. More... | |
| IControllerComponent & | operator= (IControllerComponent &&arg) noexcept=default | 
| The move assignment operator. More... | |
| IControllerComponent & | operator= (const IControllerComponent &arg)=delete | 
| The copy assignment operator is deleted. More... | |
| virtual | ~IControllerComponent (void)=default | 
| The virtual default destructor. | |
The Acf will use this interface to start and stop components during system startup and shutdown, respectively.
This is a quite important interface of the Arp platform. This is an extension to the basic IComponent interface and shall be implemented by components providing its own threads.
Asynchronous programming might be extremely difficult and error prone. This interface supports the component developer to get rid of the most multi-threading issues. There is a clear and strict asynchronous design and pattern in the Arp platform. During the startup phase, there is no asynchronism. This comes up not until calling the IControllerComponent::Start() operation and ends when calling the IControllerComponent::Stop() operation
| 
 | protecteddefaultnoexcept | 
The move constructor.
| arg | The argument to move. | 
| 
 | protecteddelete | 
The copy constructor is deleted.
| arg | The argument to copy. | 
| 
 | protecteddelete | 
The copy assignment operator is deleted.
| arg | The argument to copy. | 
| 
 | protecteddefaultnoexcept | 
The move assignment operator.
| arg | The argument to move. | 
| 
 | pure virtual | 
Starts this component, that is, the component starts its own threads.
It is recommended to use the Arp::System::Commons::Threading::WorkerThread class for own threads.