org.apache.rocketmq.store.SelectMappedBufferResult Maven / Gradle / Ivy
The newest version!
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You 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 org.apache.rocketmq.store;
import java.nio.ByteBuffer;
import org.apache.rocketmq.store.logfile.MappedFile;
public class SelectMappedBufferResult {
private final long startOffset;
private final ByteBuffer byteBuffer;
private int size;
protected MappedFile mappedFile;
private boolean isInCache = true;
public SelectMappedBufferResult(long startOffset, ByteBuffer byteBuffer, int size, MappedFile mappedFile) {
this.startOffset = startOffset;
this.byteBuffer = byteBuffer;
this.size = size;
this.mappedFile = mappedFile;
}
public ByteBuffer getByteBuffer() {
return byteBuffer;
}
public int getSize() {
return size;
}
public void setSize(final int s) {
this.size = s;
this.byteBuffer.limit(this.size);
}
public MappedFile getMappedFile() {
return mappedFile;
}
public synchronized void release() {
if (this.mappedFile != null) {
this.mappedFile.release();
this.mappedFile = null;
}
}
public synchronized boolean hasReleased() {
return this.mappedFile == null;
}
public long getStartOffset() {
return startOffset;
}
public boolean isInMem() {
if (mappedFile == null) {
return true;
}
long pos = startOffset - mappedFile.getFileFromOffset();
return mappedFile.isLoaded(pos, size);
}
public boolean isInCache() {
return isInCache;
}
public void setInCache(boolean inCache) {
isInCache = inCache;
}
}