com.landawn.abacus.util.stream.DoubleIteratorEx Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of abacus-android-se Show documentation
Show all versions of abacus-android-se Show documentation
A general programming library in Java
The newest version!
/*
* Copyright (C) 2016, 2017, 2018, 2019 HaiYang Li
*
* 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.landawn.abacus.util.stream;
import java.util.Iterator;
import java.util.NoSuchElementException;
import com.landawn.abacus.annotation.Internal;
import com.landawn.abacus.util.DoubleIterator;
import com.landawn.abacus.util.DoubleList;
import com.landawn.abacus.util.N;
import com.landawn.abacus.util.function.Supplier;
/**
*
*/
@Internal
public abstract class DoubleIteratorEx extends DoubleIterator implements IteratorEx {
public static final DoubleIteratorEx EMPTY = new DoubleIteratorEx() {
@Override
public boolean hasNext() {
return false;
}
@Override
public double nextDouble() {
throw new NoSuchElementException();
}
@Override
public void skip(long n) {
// Do nothing.
}
@Override
public long count() {
return 0;
}
@Override
public double[] toArray() {
return N.EMPTY_DOUBLE_ARRAY;
}
@Override
public void close() {
// Do nothing.
}
};
public static DoubleIteratorEx empty() {
return EMPTY;
}
@SafeVarargs
public static DoubleIteratorEx of(final double... a) {
return N.isNullOrEmpty(a) ? EMPTY : of(a, 0, a.length);
}
public static DoubleIteratorEx of(final double[] a, final int fromIndex, final int toIndex) {
N.checkFromToIndex(fromIndex, toIndex, N.len(a));
if (fromIndex == toIndex) {
return EMPTY;
}
return new DoubleIteratorEx() {
private int cursor = fromIndex;
@Override
public boolean hasNext() {
return cursor < toIndex;
}
@Override
public double nextDouble() {
if (cursor >= toIndex) {
throw new NoSuchElementException();
}
return a[cursor++];
}
@Override
public void skip(long n) {
N.checkArgNotNegative(n, "n");
cursor = n < toIndex - cursor ? cursor + (int) n : toIndex;
}
@Override
public long count() {
return toIndex - cursor;
}
@Override
public double[] toArray() {
return N.copyOfRange(a, cursor, toIndex);
}
@Override
public DoubleList toList() {
return DoubleList.of(N.copyOfRange(a, cursor, toIndex));
}
@Override
public void close() {
// Do nothing.
}
};
}
public static DoubleIteratorEx of(final DoubleIterator iter) {
if (iter == null) {
return empty();
} else if (iter instanceof DoubleIteratorEx) {
return ((DoubleIteratorEx) iter);
}
return new DoubleIteratorEx() {
@Override
public boolean hasNext() {
return iter.hasNext();
}
@Override
public double nextDouble() {
return iter.nextDouble();
}
@Override
public void close() {
// Do nothing.
}
};
}
/**
* Lazy evaluation.
*
* @param iteratorSupplier
* @return
*/
public static DoubleIteratorEx of(final Supplier extends DoubleIterator> iteratorSupplier) {
N.checkArgNotNull(iteratorSupplier, "iteratorSupplier");
return new DoubleIteratorEx() {
private DoubleIterator iter = null;
private DoubleIteratorEx iterEx = null;
private boolean isInitialized = false;
@Override
public boolean hasNext() {
if (isInitialized == false) {
init();
}
return iter.hasNext();
}
@Override
public double nextDouble() {
if (isInitialized == false) {
init();
}
return iter.nextDouble();
}
@Override
public void skip(long n) {
N.checkArgNotNegative(n, "n");
if (isInitialized == false) {
init();
}
if (iterEx != null) {
iterEx.skip(n);
} else {
super.skip(n);
}
}
@Override
public long count() {
if (isInitialized == false) {
init();
}
if (iterEx != null) {
return iterEx.count();
} else {
return super.count();
}
}
@Override
public void close() {
if (isInitialized == false) {
init();
}
if (iterEx != null) {
iterEx.close();
}
}
private void init() {
if (isInitialized == false) {
isInitialized = true;
iter = iteratorSupplier.get();
iterEx = iter instanceof DoubleIteratorEx ? (DoubleIteratorEx) iter : null;
}
}
};
}
/**
* Lazy evaluation.
*
* @param arraySupplier
* @return
*/
public static DoubleIteratorEx oF(final Supplier arraySupplier) {
N.checkArgNotNull(arraySupplier, "arraySupplier");
return new DoubleIteratorEx() {
private DoubleIteratorEx iterEx = null;
private boolean isInitialized = false;
@Override
public boolean hasNext() {
if (isInitialized == false) {
init();
}
return iterEx.hasNext();
}
@Override
public double nextDouble() {
if (isInitialized == false) {
init();
}
return iterEx.nextDouble();
}
@Override
public void skip(long n) {
N.checkArgNotNegative(n, "n");
if (isInitialized == false) {
init();
}
iterEx.skip(n);
}
@Override
public long count() {
if (isInitialized == false) {
init();
}
return iterEx.count();
}
private void init() {
if (isInitialized == false) {
isInitialized = true;
double[] aar = arraySupplier.get();
iterEx = DoubleIteratorEx.of(aar);
}
}
};
}
public static DoubleIteratorEx from(final Iterator iter) {
if (iter == null) {
return empty();
} else if (iter instanceof ObjIteratorEx) {
final ObjIteratorEx iteratorEx = ((ObjIteratorEx) iter);
return new DoubleIteratorEx() {
@Override
public boolean hasNext() {
return iteratorEx.hasNext();
}
@Override
public double nextDouble() {
return iteratorEx.next();
}
@Override
public void skip(long n) {
N.checkArgNotNegative(n, "n");
iteratorEx.skip(n);
}
@Override
public long count() {
return iteratorEx.count();
}
@Override
public void close() {
iteratorEx.close();
}
};
} else {
return new DoubleIteratorEx() {
@Override
public boolean hasNext() {
return iter.hasNext();
}
@Override
public double nextDouble() {
return iter.next();
}
@Override
public void close() {
// Do nothing.
}
};
}
}
@Override
public void skip(long n) {
N.checkArgNotNegative(n, "n");
while (n > 0 && hasNext()) {
nextDouble();
n--;
}
}
@Override
public long count() {
long result = 0;
while (hasNext()) {
nextDouble();
result++;
}
return result;
}
@Override
public void close() {
// Do nothing.
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy