/*
* Copyright (C) 2002-2019 Sebastiano Vigna
*
* 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 it.unimi.dsi.fastutil.doubles;
import java.util.AbstractCollection;
An abstract class providing basic methods for collections implementing a
type-specific interface.
In particular, this class provide iterator()
, add()
, remove(Object)
and contains(Object)
methods that just call the type-specific counterpart.
Warning: Because of a name clash between the list and collection interfaces the type-specific deletion method of a type-specific abstract collection is rem()
, rather then remove()
. A subclass must thus override rem()
, rather than remove()
, to make all inherited methods work properly.
/**
* An abstract class providing basic methods for collections implementing a
* type-specific interface.
*
* <p>
* In particular, this class provide {@link #iterator()}, {@code add()},
* {@link #remove(Object)} and {@link #contains(Object)} methods that just call
* the type-specific counterpart.
*
* <p>
* <strong>Warning</strong>: Because of a name clash between the list and
* collection interfaces the type-specific deletion method of a type-specific
* abstract collection is {@code rem()}, rather then {@code remove()}. A
* subclass must thus override {@code rem()}, rather than {@code remove()}, to
* make all inherited methods work properly.
*/
public abstract class AbstractDoubleCollection extends AbstractCollection<Double> implements DoubleCollection {
protected AbstractDoubleCollection() {
}
@Override
public abstract DoubleIterator iterator();
{@inheritDoc}
This implementation always throws an UnsupportedOperationException
.
/**
* {@inheritDoc}
*
* <p>
* This implementation always throws an {@link UnsupportedOperationException}.
*/
@Override
public boolean add(final double k) {
throw new UnsupportedOperationException();
}
{@inheritDoc}
This implementation iterates over the elements in the collection, looking for
the specified element.
/**
* {@inheritDoc}
*
* <p>
* This implementation iterates over the elements in the collection, looking for
* the specified element.
*/
@Override
public boolean contains(final double k) {
final DoubleIterator iterator = iterator();
while (iterator.hasNext())
if (k == iterator.nextDouble())
return true;
return false;
}
{@inheritDoc}
This implementation iterates over the elements in the collection, looking for
the specified element and tries to remove it.
/**
* {@inheritDoc}
*
* <p>
* This implementation iterates over the elements in the collection, looking for
* the specified element and tries to remove it.
*/
@Override
public boolean rem(final double k) {
final DoubleIterator iterator = iterator();
while (iterator.hasNext())
if (k == iterator.nextDouble()) {
iterator.remove();
return true;
}
return false;
}
{@inheritDoc}
Deprecated: Please use the corresponding type-specific method instead.
/**
* {@inheritDoc}
*
* @deprecated Please use the corresponding type-specific method instead.
*/
@SuppressWarnings("deprecation")
@Deprecated
@Override
public boolean add(final Double key) {
return DoubleCollection.super.add(key);
}
{@inheritDoc}
Deprecated: Please use the corresponding type-specific method instead.
/**
* {@inheritDoc}
*
* @deprecated Please use the corresponding type-specific method instead.
*/
@Deprecated
@Override
public boolean contains(final Object key) {
return DoubleCollection.super.contains(key);
}
{@inheritDoc}
Deprecated: Please use the corresponding type-specific method instead.
/**
* {@inheritDoc}
*
* @deprecated Please use the corresponding type-specific method instead.
*/
@Deprecated
@Override
public boolean remove(final Object key) {
return DoubleCollection.super.remove(key);
}
@Override
public double[] toArray(double a[]) {
if (a == null || a.length < size())
a = new double[size()];
DoubleIterators.unwrap(iterator(), a);
return a;
}
@Override
public double[] toDoubleArray() {
return toArray((double[]) null);
}
{@inheritDoc}
Deprecated: Please use toArray()
instead—this method is redundant and will be removed in the future.
/**
* {@inheritDoc}
*
* @deprecated Please use {@code toArray()} instead—this method is
* redundant and will be removed in the future.
*/
@Deprecated
@Override
public double[] toDoubleArray(final double a[]) {
return toArray(a);
}
@Override
public boolean addAll(final DoubleCollection c) {
boolean retVal = false;
for (final DoubleIterator i = c.iterator(); i.hasNext();)
if (add(i.nextDouble()))
retVal = true;
return retVal;
}
@Override
public boolean containsAll(final DoubleCollection c) {
for (final DoubleIterator i = c.iterator(); i.hasNext();)
if (!contains(i.nextDouble()))
return false;
return true;
}
@Override
public boolean removeAll(final DoubleCollection c) {
boolean retVal = false;
for (final DoubleIterator i = c.iterator(); i.hasNext();)
if (rem(i.nextDouble()))
retVal = true;
return retVal;
}
@Override
public boolean retainAll(final DoubleCollection c) {
boolean retVal = false;
for (final DoubleIterator i = iterator(); i.hasNext();)
if (!c.contains(i.nextDouble())) {
i.remove();
retVal = true;
}
return retVal;
}
@Override
public String toString() {
final StringBuilder s = new StringBuilder();
final DoubleIterator i = iterator();
int n = size();
double k;
boolean first = true;
s.append("{");
while (n-- != 0) {
if (first)
first = false;
else
s.append(", ");
k = i.nextDouble();
s.append(String.valueOf(k));
}
s.append("}");
return s.toString();
}
}