All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.picocontainer.Startable Maven / Gradle / Ivy

There is a newer version: 2.15
Show newest version
/*****************************************************************************
 * Copyright (c) PicoContainer Organization. All rights reserved.            *
 * ------------------------------------------------------------------------- *
 * The software in this package is published under the terms of the BSD      *
 * style license a copy of which has been included with this distribution in *
 * the license.html file.                                                    *
 *                                                                           *
 * Idea by Rachel Davies, Original code by Aslak Hellesoy and Paul Hammant   *
 *****************************************************************************/

package org.picocontainer;

/**
 * 

An interface which is implemented by components that can be started and stopped. The {@link Startable#start()} * must be called at the begin of the component lifecycle. It can be called again only after a call to * {@link Startable#stop()}. The {@link Startable#stop()} method must be called at the end of the component lifecycle, * and can further be called after every {@link Startable#start()}. If a component implements the {@link Disposable} * interface as well, {@link Startable#stop()} should be called before {@link Disposable#dispose()}.

*

*

For more advanced and pluggable lifecycle support, see the functionality offered by picocontainer-gems * subproject.

* @see org.picocontainer.Disposable the Disposable interface if you need to dispose() semantics. * @author Paul Hammant * @author Aslak Hellesøy */ public interface Startable { /** * Start this component. Called initially at the begin of the lifecycle. It can be called again after a stop. */ void start(); /** * Stop this component. Called near the end of the lifecycle. It can be called again after a further start. Implement * {@link Disposable} if you need a single call at the definite end of the lifecycle. */ void stop(); }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy