本文整理匯總了Java中java.util.ListIterator.hasPrevious方法的典型用法代碼示例。如果您正苦於以下問題:Java ListIterator.hasPrevious方法的具體用法?Java ListIterator.hasPrevious怎麽用?Java ListIterator.hasPrevious使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類java.util.ListIterator
的用法示例。
在下文中一共展示了ListIterator.hasPrevious方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。
示例1: getPrevious
import java.util.ListIterator; //導入方法依賴的package包/類
private static CanvasObject getPrevious(CanvasObject query, List<CanvasObject> objs, CanvasModel model,
Collection<? extends CanvasObject> ignore) {
int index = getIndex(query, objs);
if (index <= 0) {
return null;
} else {
Set<CanvasObject> set = toSet(model.getObjectsOverlapping(query));
ListIterator<CanvasObject> it = objs.listIterator(index);
while (it.hasPrevious()) {
CanvasObject o = it.previous();
if (set.contains(o) && !ignore.contains(o))
return o;
}
return null;
}
}
示例2: getConvertedTree
import java.util.ListIterator; //導入方法依賴的package包/類
public ElasticsearchPrel getConvertedTree() {
ElasticsearchPrel subTree = (ElasticsearchPrel) this.child;
if (filterExprs != null) {
subTree = new ElasticsearchFilter(subTree.getCluster(), subTree.getTraitSet(), subTree, filterExprs, subTree.getPluginId());
}
if (projectExprs != null) {
subTree = new ElasticsearchProject(subTree.getCluster(), subTree.getTraitSet(), subTree, projectExprs, projectDataType, subTree.getPluginId());
}
if (parents != null && !parents.isEmpty()) {
ListIterator<ElasticsearchPrel> iterator = parents.listIterator(parents.size());
while (iterator.hasPrevious()) {
final ElasticsearchPrel parent = iterator.previous();
subTree = (ElasticsearchPrel) parent.copy(parent.getTraitSet(), Collections.singletonList((RelNode) subTree));
}
}
return subTree;
}
示例3: descendingIterator
import java.util.ListIterator; //導入方法依賴的package包/類
@Override
public final Iterator<Object> descendingIterator() {
final ListIterator<Object> it = listIterator(size());
return new Iterator<Object>() {
@Override
public boolean hasNext() {
return it.hasPrevious();
}
@Override
public Object next() {
return it.previous();
}
@Override
public void remove() {
it.remove();
}
};
}
示例4: testHasPrevious
import java.util.ListIterator; //導入方法依賴的package包/類
/**
* Test of hasPrevious method, of class TreeListIterator.
*/
@Test
public void testHasPrevious() {
ListIterator<TreeNode> treeListIterator1 = new TreeListIterator(tree1);
boolean expResult = true;
for(int i = 0; i < 14; i++) {
treeListIterator1.next();
}
boolean result = treeListIterator1.hasPrevious();
assertEquals("hasPrevious method, of class TreeListIterator's expected result is wrong.",
expResult, result);
ListIterator<TreeNode> treeListIterator2 = new TreeListIterator(tree2);
expResult = false;
result = treeListIterator2.hasPrevious();
assertEquals("hasPrevious method, of class TreeListIterator's expected result is wrong.",
expResult, result);
}
示例5: getIterator
import java.util.ListIterator; //導入方法依賴的package包/類
/**
* Returns an iterator for the specified glyphs, sorted either ascending or descending.
*
* @param glyphs The glyphs to return if present
* @return An iterator of the sorted list of glyphs
*/
private Iterator getIterator(List glyphs) {
if (orderAscending) return glyphs.iterator();
final ListIterator iter = glyphs.listIterator(glyphs.size());
return new Iterator() {
public boolean hasNext () {
return iter.hasPrevious();
}
public Object next () {
return iter.previous();
}
public void remove () {
iter.remove();
}
};
}
示例6: checkType
import java.util.ListIterator; //導入方法依賴的package包/類
public TCType checkType(POExpression exp, TCType expected)
{
ListIterator<POContext> p = this.listIterator(size());
while (p.hasPrevious())
{
POContext c = p.previous();
if (c.isScopeBoundary())
{
break; // Change of name scope for expressions.
}
TCType t = c.checkType(exp);
if (t != null)
{
return t;
}
}
return expected;
}
示例7: searchBackwards
import java.util.ListIterator; //導入方法依賴的package包/類
public int searchBackwards(String searchTerm, int startIndex, boolean startsWith) {
ListIterator<History.Entry> it = history.entries(startIndex);
while (it.hasPrevious()) {
History.Entry e = it.previous();
if (startsWith) {
if (e.value().toString().startsWith(searchTerm)) {
return e.index();
}
} else {
if (e.value().toString().contains(searchTerm)) {
return e.index();
}
}
}
return -1;
}
示例8: addSeenViews
import java.util.ListIterator; //導入方法依賴的package包/類
private static void addSeenViews(List<RouterTransaction> stack, ViewGroup container) {
ListIterator<RouterTransaction> iterable = stack.listIterator(stack.size());
int index = container.getChildCount();
boolean isTop = true;
while(iterable.hasPrevious()) {
Controller controller = iterable.previous().controller();
// Ensure the view is shown
View view = controller.getView();
if (view == null) {
view = controller.inflate(container);
}
if (view.getParent() == null) {
container.addView(view, index);
}
// Update index
index = container.indexOfChild(view);
// Check controller opacity
int opacity = getControllerOpacity(controller);
if (opacity == ControllerOpacity.OPAQUE ||
(opacity == ControllerOpacity.TRANSLUCENT && !isTop)) {
// The controllers below can't be seen
break;
}
isTop = false;
}
}
示例9: loadLastConfigs
import java.util.ListIterator; //導入方法依賴的package包/類
/**
* @return last non-empty result from input persisters
*/
@Override
public List<ConfigSnapshotHolder> loadLastConfigs() {
// iterate in reverse order
ListIterator<PersisterWithConfiguration> li = persisterWithConfigurations.listIterator(persisterWithConfigurations.size());
while(li.hasPrevious()) {
PersisterWithConfiguration persisterWithConfiguration = li.previous();
List<ConfigSnapshotHolder> configs = null;
try {
configs = persisterWithConfiguration.storage.loadLastConfigs();
} catch (final IOException e) {
throw new RuntimeException("Error while calling loadLastConfig on " + persisterWithConfiguration, e);
}
if (!configs.isEmpty()) {
LOG.debug("Found non empty configs using {}:{}", persisterWithConfiguration, configs);
return configs;
}
}
// no storage had an answer
LOG.debug("No non-empty list of configuration snapshots found");
return Collections.emptyList();
}
示例10: destroy
import java.util.ListIterator; //導入方法依賴的package包/類
@Override
@SuppressWarnings( {"unchecked"})
public void destroy() {
if ( !active ) {
return;
}
active = false;
try {
synchronized (serviceBindingList) {
ListIterator<ServiceBinding> serviceBindingsIterator = serviceBindingList.listIterator(
serviceBindingList.size()
);
while ( serviceBindingsIterator.hasPrevious() ) {
final ServiceBinding serviceBinding = serviceBindingsIterator.previous();
serviceBinding.getLifecycleOwner().stopService( serviceBinding );
}
serviceBindingList.clear();
}
serviceBindingMap.clear();
}
finally {
parent.deRegisterChild( this );
}
}
示例11: _renderIconRowRtl
import java.util.ListIterator; //導入方法依賴的package包/類
private void _renderIconRowRtl(
FacesContext context,
RenderingContext rc,
UIXProcess process,
Train train
) throws IOException
{
ParentTrain parentTrain = train.getParentTrain();
// Render parent end
if(parentTrain != null && parentTrain.hasParentEnd())
{
_renderParentEndRtl(context, rc, process, train);
}
List<Station> stations = train.getStations();
ListIterator<Station> iterator = stations.listIterator(stations.size());
while(iterator.hasPrevious())
{
_renderStationIconRtl(context, rc, process, iterator.previous());
}
// Render parent start
if(parentTrain != null && parentTrain.hasParentStart())
{
_renderParentStartRtl(context, rc, process, train);
}
}
示例12: resetOffset
import java.util.ListIterator; //導入方法依賴的package包/類
public boolean resetOffset(long offset) {
MappedFile mappedFileLast = getLastMappedFile();
if (mappedFileLast != null) {
long lastOffset = mappedFileLast.getFileFromOffset() +
mappedFileLast.getWrotePosition();
long diff = lastOffset - offset;
final int maxDiff = this.mappedFileSize * 2;
if (diff > maxDiff)
return false;
}
ListIterator<MappedFile> iterator = this.mappedFiles.listIterator();
while (iterator.hasPrevious()) {
mappedFileLast = iterator.previous();
if (offset >= mappedFileLast.getFileFromOffset()) {
int where = (int) (offset % mappedFileLast.getFileSize());
mappedFileLast.setFlushedPosition(where);
mappedFileLast.setWrotePosition(where);
mappedFileLast.setCommittedPosition(where);
break;
} else {
iterator.remove();
}
}
return true;
}
示例13: pickCommentNoDoubleStar
import java.util.ListIterator; //導入方法依賴的package包/類
/**
* Select comment closest to lookup element. Assume comments to be ordered list. Ignores comments starting with
* doublestar.
*
* @param comments
* list of commnets on luukup elements
* @throws InstantiationException
* if comment is malformed
*/
protected CommentCandidate pickCommentNoDoubleStar(List<INode> comments) throws InstantiationException {
ListIterator<INode> iter = comments.listIterator(comments.size());
String candidateTextString = null;
while (iter.hasPrevious()) {
candidateTextString = iter.previous().getText();
if (!candidateTextString.startsWith("/**")) {
return new CommentCandidate(candidateTextString);
}
}
return null;
}
示例14: dequeueKeyEvents
import java.util.ListIterator; //導入方法依賴的package包/類
/**
* Releases for normal dispatching to the current focus owner all
* KeyEvents which were enqueued because of a call to
* {@code enqueueKeyEvents} with the same timestamp and Component.
* If the given timestamp is less than zero, the outstanding enqueue
* request for the given Component with the <b>oldest</b> timestamp (if
* any) should be cancelled.
*
* @param after the timestamp specified in the call to
* {@code enqueueKeyEvents}, or any value < 0
* @param untilFocused the Component specified in the call to
* {@code enqueueKeyEvents}
* @see #enqueueKeyEvents
* @see #discardKeyEvents
*/
protected synchronized void dequeueKeyEvents(long after,
Component untilFocused) {
if (untilFocused == null) {
return;
}
if (focusLog.isLoggable(PlatformLogger.Level.FINER)) {
focusLog.finer("Dequeue at {0} for {1}",
after, untilFocused);
}
TypeAheadMarker marker;
ListIterator<TypeAheadMarker> iter = typeAheadMarkers.listIterator
((after >= 0) ? typeAheadMarkers.size() : 0);
if (after < 0) {
while (iter.hasNext()) {
marker = iter.next();
if (marker.untilFocused == untilFocused)
{
iter.remove();
return;
}
}
} else {
while (iter.hasPrevious()) {
marker = iter.previous();
if (marker.untilFocused == untilFocused &&
marker.after == after)
{
iter.remove();
return;
}
}
}
}
示例15: freeCachedConnections
import java.util.ListIterator; //導入方法依賴的package包/類
private void freeCachedConnections() {
/*
* Remove each connection whose time out has expired.
*/
synchronized (freeList) {
int size = freeList.size();
if (size > 0) {
long time = System.currentTimeMillis();
ListIterator<TCPConnection> iter = freeList.listIterator(size);
while (iter.hasPrevious()) {
TCPConnection conn = iter.previous();
if (conn.expired(time)) {
TCPTransport.tcpLog.log(Log.VERBOSE,
"connection timeout expired");
try {
conn.close();
} catch (java.io.IOException e) {
// eat exception
}
iter.remove();
}
}
}
if (freeList.isEmpty()) {
reaper.cancel(false);
reaper = null;
}
}
}