
com.alipay.sofa.jraft.closure.ClosureQueue Maven / Gradle / Ivy
/*
* 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 com.alipay.sofa.jraft.closure;
import java.util.List;
import javax.annotation.concurrent.ThreadSafe;
import com.alipay.sofa.jraft.Closure;
/**
* A thread-safe closure queue.
*
* @author boyan ([email protected])
*
* 2018-Mar-14 10:29:12 AM
*/
@ThreadSafe
public interface ClosureQueue {
/**
* Clear all closure in queue.
*/
void clear();
/**
* Reset the first index in queue.
*
* @param firstIndex the first index of queue
*/
void resetFirstIndex(final long firstIndex);
/**
* Append a new closure into queue.
*
* @param closure the closure to append
*/
void appendPendingClosure(final Closure closure);
/**
* Pop closure from queue until index(inclusion), returns the first
* popped out index, returns -1 when out of range, returns index+1
* when not found.
*
* @param endIndex the index of queue
* @param closures closure list
* @return returns the first popped out index, returns -1 when out
* of range, returns index+1
* when not found.
*/
long popClosureUntil(final long endIndex, final List closures);
/**
* Pop closure from queue until index(inclusion), returns the first
* popped out index, returns -1 when out of range, returns index+1
* when not found.
*
* @param endIndex the index of queue
* @param closures closure list
* @param taskClosures task closure list
* @return returns the first popped out index, returns -1 when out
* of range, returns index+1
* when not found.
*/
long popClosureUntil(final long endIndex, final List closures, final List taskClosures);
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy