com.kapil.framework.concurrent.impl.AbstractProducer Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of iframework Show documentation
Show all versions of iframework Show documentation
This is a set of utilities and classes that I have found useful over the years.
In my career spanning over a decade, I have time and again written the same code or
some part of the code over and over again. I never found the time to collate the details
in a reusable library. This project will be a collection of such files.
The work that I have been doing is more than 5 years old, however the project has been
conceived in 2011.
/*******************************************************************************
* Copyright 2011 @ Kapil Viren Ahuja
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
******************************************************************************/
package com.kapil.framework.concurrent.impl;
import com.kapil.framework.concurrent.IBroker;
import com.kapil.framework.concurrent.IProducer;
/**
*
* This class provided basic and common functionality for any class that wants to implement {@link IProducer} and
* provide the following functionalities:
*
*
*
* This class allows the {@link Thread} until the sub-class sets the {@link IBroker#isProducing()}
* to FALSE
*
*
*
* @author Kapil Viren Ahuja
*
* @param
*/
public abstract class AbstractProducer implements IProducer
{
private IBroker broker;
/**
* Default Constructor that initializes the Producer with a name and {@link IBroker}.
*
* @param name
* @param broker
*/
public AbstractProducer(IBroker broker)
{
this.broker = broker;
}
/**
* Function that is invoked when the {@link Thread} starts and is the entry point for the functionality.
*
*/
public void run()
{
doPopulateBroker();
// In most cases, the concrete implementation should not worry about stop producing, and hence this
// should be executed here, but in some cases the concrete implementation may stop the production
if (this.broker.isProducing())
{
this.broker.stopProducing();
}
System.out.println("Producer is shutting down");
}
/**
* Add the data into the {@link IBroker}.
*
* @param data
*/
public void updateBroker(V data)
{
try
{
this.broker.put(data);
}
catch (InterruptedException iex)
{
iex.printStackTrace();
}
}
/**
* This is an abstract method that allows any class extending this class to write to perform core logic.
*
* @param data
*/
protected abstract void doPopulateBroker();
}