Represents a sequence of integer values, either ascending or descending. : Range « Collections Data Structure « Java






Represents a sequence of integer values, either ascending or descending.

       

// Copyright 2006 The Apache Software Foundation
//
// 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.


import java.util.Iterator;

/**
 * Represents a sequence of integer values, either ascending or descending. The sequence is always inclusive (of the
 * finish value).
 */
public final class IntegerRange implements Iterable<Integer>
{
    private final int start;

    private final int finish;

    private class RangeIterator implements Iterator<Integer>
    {
        private final int increment;

        private int value = start;

        private boolean hasNext = true;

        RangeIterator()
        {
            increment = start < finish ? +1 : -1;
        }

        public boolean hasNext()
        {
            return hasNext;
        }

        public Integer next()
        {
            if (!hasNext) throw new IllegalStateException();

            int result = value;

            hasNext = value != finish;

            value += increment;

            return result;
        }

        public void remove()
        {
            throw new UnsupportedOperationException();
        }

    }

    public IntegerRange(final int start, final int finish)
    {
        this.start = start;
        this.finish = finish;
    }

    public int getFinish()
    {
        return finish;
    }

    public int getStart()
    {
        return start;
    }

    @Override
    public String toString()
    {
        return String.format("%d..%d", start, finish);
    }

    /**
     * The main puprose of a range object is to produce an Iterator. Since IntegerRange is iterable, it is useful with
     * the Tapestry Loop component, but also with the Java for loop!
     */
    public Iterator<Integer> iterator()
    {
        return new RangeIterator();
    }

    @Override
    public int hashCode()
    {
        final int PRIME = 31;

        int result = PRIME + finish;

        result = PRIME * result + start;

        return result;
    }

    /**
     * Returns true if the other object is an IntegerRange with the same start and finish values.
     */
    @Override
    public boolean equals(Object obj)
    {
        if (this == obj) return true;
        if (obj == null) return false;
        if (getClass() != obj.getClass()) return false;
        final IntegerRange other = (IntegerRange) obj;
        if (finish != other.finish) return false;

        return start == other.start;
    }

}

   
    
    
    
    
    
    
  








Related examples in the same category

1.This constructs an Iterator over each day in a date range defined by a focus date and range style.
2.Finds the value in the range (start,limit) of the largest element (rank) where the count of all smaller elements in that range is less than or equals target.
3.IntRange represents an inclusive range of ints.
4.LongRange represents an inclusive range of longs.
5.Byte Range
6.NumberRange represents an inclusive range of java.lang.Number objects of the same type.
7.Represents a range of Number objects.
8.A numeric range has a high, low, mean, root-mean-square, standard deviation, and the count of how many samples it contains.
9.A range of integers.
10.Value Range generic structure
11.Long Range
12.Class for storing start and end integer offsets.
13.Integer Sequence Generator
14.A numerical interval