當前位置: 首頁>>代碼示例>>Java>>正文


Java AbstractIterator類代碼示例

本文整理匯總了Java中com.google.common.collect.AbstractIterator的典型用法代碼示例。如果您正苦於以下問題:Java AbstractIterator類的具體用法?Java AbstractIterator怎麽用?Java AbstractIterator使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


AbstractIterator類屬於com.google.common.collect包,在下文中一共展示了AbstractIterator類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Java代碼示例。

示例1: iterator

import com.google.common.collect.AbstractIterator; //導入依賴的package包/類
/**
 * Provides an efficient summary of the changes, without doing too much unnecessary work.
 * - Will only emit changes of a single type (from a single delegate change set)
 * - Will return no more than the specified maximum of number of changes
 */
public Iterator<TaskStateChange> iterator() {

    return new AbstractIterator<TaskStateChange>() {
        Iterator<TaskStateChange> changes;
        int count;

        @Override
        protected TaskStateChange computeNext() {
            if (changes == null) {
                changes = firstDirtyIterator();
            }

            if (count < maxReportedChanges && changes != null && changes.hasNext()) {
                count++;
                return changes.next();
            }
            return endOfData();
        }
    };
}
 
開發者ID:lxxlxx888,項目名稱:Reer,代碼行數:26,代碼來源:SummaryTaskStateChanges.java

示例2: iterator

import com.google.common.collect.AbstractIterator; //導入依賴的package包/類
/**
 * Iterator over all present inhabitants of ordinal domain.
 * @return snapshot iterator of elements in ordinal domain.
 */
@Override
public Iterator<E> iterator() {
  return new AbstractIterator<E>() {
    private final int length = length();
    private int index = 0;

    @Override
    protected E computeNext() {
      int p = index++;
      if (p < length) {
        return get(p);
      }
      return endOfData();
    }
  };
}
 
開發者ID:weiwenqiang,項目名稱:GitHub,代碼行數:21,代碼來源:OrdinalDomain.java

示例3: metrics

import com.google.common.collect.AbstractIterator; //導入依賴的package包/類
@Override public Iterable<AbstractMetric> metrics() {
  return new Iterable<AbstractMetric>() {
    final Iterator<AbstractMetric> it = delegate.metrics().iterator();
    @Override public Iterator<AbstractMetric> iterator() {
      return new AbstractIterator<AbstractMetric>() {
        @Override public AbstractMetric computeNext() {
          while (it.hasNext()) {
            AbstractMetric next = it.next();
            if (filter.accepts(next.name())) {
              return next;
            }
          }
          return endOfData();
        }
      };
    }
  };
}
 
開發者ID:nucypher,項目名稱:hadoop-oss,代碼行數:19,代碼來源:MetricsRecordFiltered.java

示例4: iterator

import com.google.common.collect.AbstractIterator; //導入依賴的package包/類
@Override
public UnmodifiableIterator<E> iterator() {
  final Iterator<? extends Entry<E, ?>> entries = outEdgeToNode.entrySet().iterator();
  return new AbstractIterator<E>() {
    @Override
    protected E computeNext() {
      while (entries.hasNext()) {
        Entry<E, ?> entry = entries.next();
        if (targetNode.equals(entry.getValue())) {
          return entry.getKey();
        }
      }
      return endOfData();
    }
  };
}
 
開發者ID:zugzug90,項目名稱:guava-mock,代碼行數:17,代碼來源:MultiEdgesConnecting.java

示例5: linesIterator

import com.google.common.collect.AbstractIterator; //導入依賴的package包/類
/**
 * Returns an iterator over the lines in the string. If the string ends in a newline, a final
 * empty string is not included, to match the behavior of BufferedReader/LineReader.readLine().
 */
private Iterator<String> linesIterator() {
  return new AbstractIterator<String>() {
    Iterator<String> lines = LINE_SPLITTER.split(seq).iterator();

    @Override
    protected String computeNext() {
      if (lines.hasNext()) {
        String next = lines.next();
        // skip last line if it's empty
        if (lines.hasNext() || !next.isEmpty()) {
          return next;
        }
      }
      return endOfData();
    }
  };
}
 
開發者ID:zugzug90,項目名稱:guava-mock,代碼行數:22,代碼來源:CharSource.java

示例6: iterator

import com.google.common.collect.AbstractIterator; //導入依賴的package包/類
@Override
public Iterator<C> iterator() {
  return new AbstractIterator<C>() {
    Iterator<Object[]> it = map.values().iterator();
    Object[] counters = it.hasNext() ? it.next() : null;
    int i = 0;
    @Override
    protected C computeNext() {
      while (counters != null) {
        while (i < counters.length) {
          @SuppressWarnings("unchecked")
          C counter = (C) counters[i++];
          if (counter != null) return counter;
        }
        i = 0;
        counters = it.hasNext() ? it.next() : null;
      }
      return endOfData();
    }
  };
}
 
開發者ID:naver,項目名稱:hadoop,代碼行數:22,代碼來源:FileSystemCounterGroup.java

示例7: getWrappingIterator

import com.google.common.collect.AbstractIterator; //導入依賴的package包/類
public static <T extends Object> Iterator<T> getWrappingIterator(final int startIdx, final List<T> list)
{
	return new AbstractIterator<T>()
	{
		private int idx = Math.max(0, Math.min(startIdx, list.size() - 1));

		@Override
		protected T computeNext()
		{
			T o = list.get(idx);

			idx++;
			if(idx >= list.size())
			{
				idx = 0;
			}

			return o;
		}
	};
}
 
開發者ID:Alfresco,項目名稱:alfresco-remote-api,代碼行數:22,代碼來源:RepoService.java

示例8: lines

import com.google.common.collect.AbstractIterator; //導入依賴的package包/類
/**
 * Returns an iterable over the lines in the string. If the string ends in a newline, a final
 * empty string is not included to match the behavior of BufferedReader/LineReader.readLine().
 */
private Iterable<String> lines() {
  return new Iterable<String>() {
    @Override
    public Iterator<String> iterator() {
      return new AbstractIterator<String>() {
        Iterator<String> lines = LINE_SPLITTER.split(seq).iterator();

        @Override
        protected String computeNext() {
          if (lines.hasNext()) {
            String next = lines.next();
            // skip last line if it's empty
            if (lines.hasNext() || !next.isEmpty()) {
              return next;
            }
          }
          return endOfData();
        }
      };
    }
  };
}
 
開發者ID:paul-hammant,項目名稱:googles-monorepo-demo,代碼行數:27,代碼來源:CharSource.java

示例9: entry

import com.google.common.collect.AbstractIterator; //導入依賴的package包/類
public Iterable<Entry<String, T>> entry() {
    return () -> new AbstractIterator<Entry<String, T>>() {
        NodeHolder holder;
        Iterator<String> ite;

        {
            holder = new NodeHolder();
            ite = keys(holder);
        }

        @Override
        protected Entry<String, T> computeNext() {
            if (!ite.hasNext()) {
                return endOfData();
            }
            String key = ite.next();
            if (key != null) {
                return new AbstractMap.SimpleEntry<>(key, (T) holder.node.value);
            }
            return endOfData();
        }
    };
}
 
開發者ID:mayabot,項目名稱:mynlp,代碼行數:24,代碼來源:BinTrieTree.java

示例10: iterator

import com.google.common.collect.AbstractIterator; //導入依賴的package包/類
@Override
public Iterator<Vertex> iterator() {
    return new AbstractIterator<Vertex>() {
        Vertex point = first;

        @Override
        protected Vertex computeNext() {
            if (point == null) {
                return endOfData();
            } else {
                Vertex old = point;
                point = old.next;
                return old;
            }
        }
    };
}
 
開發者ID:mayabot,項目名稱:mynlp,代碼行數:18,代碼來源:VertexRow.java

示例11: iterator

import com.google.common.collect.AbstractIterator; //導入依賴的package包/類
@Override
public Iterator<ObjectEntry<T, R>> iterator() {
  abstract class __SeparatorRegions_1 extends AbstractIterator<ObjectEntry<T, R>> {
    ObjectEntry<T, R> next;
  }
  
  return new __SeparatorRegions_1() {
    {
      next = SeparatorRegions.this.first;
    }
    @Override
    protected ObjectEntry<T, R> computeNext() {
      ObjectEntry<T, R> _xblockexpression = null;
      {
        if ((this.next == null)) {
          return this.endOfData();
        }
        final ObjectEntry<T, R> current = this.next;
        this.next = this.next.getTrailingObject();
        _xblockexpression = current;
      }
      return _xblockexpression;
    }
  };
}
 
開發者ID:eclipse,項目名稱:xtext-extras,代碼行數:26,代碼來源:SeparatorRegions.java

示例12: take

import com.google.common.collect.AbstractIterator; //導入依賴的package包/類
/**
 * Returns a view on this iterator that provides at most the first <code>count</code> entries.
 * 
 * @param iterator
 *            the iterator. May not be <code>null</code>.
 * @param count
 *            the number of elements that should be returned at most.
 * @return an iterator with <code>count</code> elements. Never <code>null</code>.
 * @throws IllegalArgumentException
 *             if <code>count</code> is negative.
 */
@Pure
public static <T> Iterator<T> take(final Iterator<T> iterator, final int count) {
	if (iterator == null)
		throw new NullPointerException("iterator");
	if (count < 0)
		throw new IllegalArgumentException("Cannot take a negative number of elements. Argument 'count' was: "
				+ count);
	if (count == 0)
		return ImmutableSet.<T>of().iterator();
	return new AbstractIterator<T>() {

		private int remaining = count;

		@Override
		protected T computeNext() {
			if (remaining <= 0)
				return endOfData();
			if (!iterator.hasNext())
				return endOfData();
			remaining--;
			return iterator.next();
		}
	};
}
 
開發者ID:eclipse,項目名稱:xtext-lib,代碼行數:36,代碼來源:IteratorExtensions.java

示例13: drop

import com.google.common.collect.AbstractIterator; //導入依賴的package包/類
/**
 * Returns a view on this iterator that provides all elements except the first <code>count</code> entries.
 * 
 * @param iterator
 *            the iterator. May not be <code>null</code>.
 * @param count
 *            the number of elements that should be dropped.
 * @return an iterator without the first <code>count</code> elements. Never <code>null</code>.
 * @throws IllegalArgumentException
 *             if <code>count</code> is negative.
 */
public static <T> Iterator<T> drop(final Iterator<T> iterator, final int count) {
	if (iterator == null)
		throw new NullPointerException("iterator");
	if (count == 0)
		return iterator;
	if (count < 0)
		throw new IllegalArgumentException("Cannot drop a negative number of elements. Argument 'count' was: "
				+ count);
	return new AbstractIterator<T>() {
		{
			int i = count;
			while (i > 0 && iterator.hasNext()) {
				iterator.next();
				i--;
			}
		}

		@Override
		protected T computeNext() {
			if (!iterator.hasNext())
				return endOfData();
			return iterator.next();
		}
	};
}
 
開發者ID:eclipse,項目名稱:xtext-lib,代碼行數:37,代碼來源:IteratorExtensions.java

示例14: takeWhile

import com.google.common.collect.AbstractIterator; //導入依賴的package包/類
/**
 * Returns an Iterator containing all elements starting from the head of the source up to and excluding the first
 * element that violates the predicate. The resulting Iterator is a lazily computed view, so any modifications to the
 * underlying Iterators will be reflected on iteration. The result does not support {@link Iterator#remove()}
 * 
 * @param iterator
 *            the elements from which to take. May not be <code>null</code>.
 * @param predicate
 *            the predicate which decides whether to keep taking elements. May not be <code>null</code>.
 * @return the taken elements
 * @since 2.7
 */
public static <T> Iterator<T> takeWhile(final Iterator<? extends T> iterator, final Function1<? super T, Boolean> predicate) {
	if (iterator == null)
		throw new NullPointerException("iterator");
	if (predicate == null)
		throw new NullPointerException("predicate");
	return new AbstractIterator<T>() {
		@Override
		protected T computeNext() {
			if (!iterator.hasNext())
				return endOfData();
			T next = iterator.next();
			if (predicate.apply(next)) {
				return next;
			} else {
				return endOfData();
			}
		}
	};
}
 
開發者ID:eclipse,項目名稱:xtext-lib,代碼行數:32,代碼來源:IteratorExtensions.java

示例15: indexed

import com.google.common.collect.AbstractIterator; //導入依賴的package包/類
/**
 * Returns an Iterator of Pairs where the nth pair is created by taking the nth element of the source as the value
 * and its 0-based index as the key. E.g.
 * <code>zipWitIndex(#["a", "b", "c"]) == #[(0, "a"), (1, "b"), (2, "c")]</code>
 * 
 * If the index would overflow, {@link Integer#MAX_VALUE} is returned for all subsequent elements.
 * 
 * The resulting Iterator is a lazily computed view, so any modifications to the underlying Iterator will be
 * reflected on iteration. The result does not support {@link Iterator#remove()}
 * 
 * @param iterator
 *            the elements. May not be <code>null</code>.
 * @return the zipped result
 * @since 2.7
 */
public static <A> Iterator<Pair<Integer, A>> indexed(final Iterator<? extends A> iterator) {
	if (iterator == null)
		throw new NullPointerException("iterator");
	return new AbstractIterator<Pair<Integer, A>>() {
		int i = 0;
		@Override
		protected Pair<Integer, A> computeNext() {
			if (iterator.hasNext()) {
				Pair<Integer, A> next = new Pair<Integer, A>(i, iterator.next());
				if (i != Integer.MAX_VALUE)
					i++;
				return next;
			} else {
				return endOfData();
			}
		}
	};
}
 
開發者ID:eclipse,項目名稱:xtext-lib,代碼行數:34,代碼來源:IteratorExtensions.java


注:本文中的com.google.common.collect.AbstractIterator類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。