com.jpattern.service.log.reader.QueueMessages Maven / Gradle / Ivy
package com.jpattern.service.log.reader;
import java.util.List;
import java.util.Vector;
/**
* @author Francesco Cina 07/ago/2009
*/
public class QueueMessages implements IQueueMessages {
private static final long serialVersionUID = 1L;
private int _maxCodaLenght = 1;
private List messageList = new Vector();
private Long lastMessageId = 0l;
private Long firstMessageId = 0l;
public QueueMessages(int maxCodaLength) {
if (maxCodaLength > 1) {
_maxCodaLenght = maxCodaLength;
}
}
public int size() {
return messageList.size();
}
public void offer(String aMessage) {
synchronized (messageList) {
if (messageList.size() >= _maxCodaLenght) {
synchronized (firstMessageId) {
firstMessageId++;
messageList.remove(0);
}
}
synchronized (lastMessageId) {
messageList.add(new QueueMessage(lastMessageId, aMessage, true));
lastMessageId++;
}
}
}
public IQueueMessage peek() {
synchronized (messageList) {
if (messageList.size() == 0) {
return new QueueMessage(0, "", false);
}
return messageList.get(0);
}
}
public IQueueMessage poll() {
synchronized (messageList) {
if (messageList.size() == 0) {
return new QueueMessage(0, "", false);
}
IQueueMessage result = messageList.get(0);
messageList.remove(0);
return result;
}
}
public IQueueMessage get(long index) {
if (index == -1l) {
return peek();
}
synchronized (messageList) {
if (index < firstMessageId || index >= lastMessageId) {
return new QueueMessage(index, "", false);
}
return messageList.get( (int) (index - firstMessageId) );
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy