com.alibaba.rocketmq.store.GetMessageResult Maven / Gradle / Ivy
/**
* Copyright (C) 2010-2013 Alibaba Group Holding Limited
*
* 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.alibaba.rocketmq.store;
import java.nio.ByteBuffer;
import java.util.ArrayList;
import java.util.List;
/**
* 访问消息返回结果
*
* @author shijia.wxr
* @since 2013-7-21
*/
public class GetMessageResult {
// 多个连续的消息集合
private final List messageMapedList =
new ArrayList(100);
// 用来向Consumer传送消息
private final List messageBufferList = new ArrayList(100);
// 枚举变量,取消息结果
private GetMessageStatus status;
// 当被过滤后,返回下一次开始的Offset
private long nextBeginOffset;
// 逻辑队列中的最小Offset
private long minOffset;
// 逻辑队列中的最大Offset
private long maxOffset;
// ByteBuffer 总字节数
private int bufferTotalSize = 0;
// 是否建议从slave拉消息
private boolean suggestPullingFromSlave = false;
public GetMessageResult() {
}
public GetMessageStatus getStatus() {
return status;
}
public void setStatus(GetMessageStatus status) {
this.status = status;
}
public long getNextBeginOffset() {
return nextBeginOffset;
}
public void setNextBeginOffset(long nextBeginOffset) {
this.nextBeginOffset = nextBeginOffset;
}
public long getMinOffset() {
return minOffset;
}
public void setMinOffset(long minOffset) {
this.minOffset = minOffset;
}
public long getMaxOffset() {
return maxOffset;
}
public void setMaxOffset(long maxOffset) {
this.maxOffset = maxOffset;
}
public List getMessageMapedList() {
return messageMapedList;
}
public List getMessageBufferList() {
return messageBufferList;
}
public void addMessage(final SelectMapedBufferResult mapedBuffer) {
this.messageMapedList.add(mapedBuffer);
this.messageBufferList.add(mapedBuffer.getByteBuffer());
this.bufferTotalSize += mapedBuffer.getSize();
}
public void release() {
for (SelectMapedBufferResult select : this.messageMapedList) {
select.release();
}
}
public int getBufferTotalSize() {
return bufferTotalSize;
}
public void setBufferTotalSize(int bufferTotalSize) {
this.bufferTotalSize = bufferTotalSize;
}
public int getMessageCount() {
return this.messageMapedList.size();
}
public boolean isSuggestPullingFromSlave() {
return suggestPullingFromSlave;
}
public void setSuggestPullingFromSlave(boolean suggestPullingFromSlave) {
this.suggestPullingFromSlave = suggestPullingFromSlave;
}
@Override
public String toString() {
return "GetMessageResult [status=" + status + ", nextBeginOffset=" + nextBeginOffset + ", minOffset="
+ minOffset + ", maxOffset=" + maxOffset + ", bufferTotalSize=" + bufferTotalSize
+ ", suggestPullingFromSlave=" + suggestPullingFromSlave + "]";
}
}