구아바-레인지 클래스

범위는 간격 또는 시퀀스를 나타냅니다. 특정 범위에있는 숫자 / 문자열 집합을 가져 오는 데 사용됩니다.

클래스 선언

다음은에 대한 선언입니다. com.google.common.collect.Range<C> 클래스-

@GwtCompatible
public final class Range<C extends Comparable>
   extends Object
      implements Predicate<C>, Serializable

행동 양식

Sr. 아니요 방법 및 설명
1

static <C extends Comparable<?>> Range<C> all()

유형 C의 모든 값을 포함하는 범위를 반환합니다.

2

boolean apply(C input)Deprecated.

Predicate 인터페이스를 만족시키기 위해서만 제공됩니다. 대신 contains (C)를 사용하십시오.

static <C extends Comparable<?>> Range<C> atLeast(C endpoint)

끝점보다 크거나 같은 모든 값을 포함하는 범위를 반환합니다.

4

static <C extends Comparable<?>> Range<C> atMost(C endpoint)

끝점보다 작거나 같은 모든 값을 포함하는 범위를 반환합니다.

5

Range<C> canonical(DiscreteDomain<C> domain)

주어진 도메인에서이 범위의 표준 형식을 반환합니다.

6

static <C extends Comparable<?>> Range<C> closed(C lower, C upper)

하한보다 크거나 같고 상한보다 작거나 같은 모든 값을 포함하는 범위를 반환합니다.

7

static <C extends Comparable<?>> Range<C> closedOpen(C lower, C upper)

하한보다 크거나 같고 상한보다 작은 값을 모두 포함하는 범위를 반환합니다.

8

boolean contains(C value)

값이이 범위의 범위 내에 있으면 true를 반환합니다.

9

boolean containsAll(Iterable<? extends C> values)

값의 모든 요소가이 범위에 포함되면 true를 반환합니다.

10

static <C extends Comparable<?>> Range<C> downTo(C endpoint, BoundType boundType)

지정된 끝점에서 범위를 반환합니다. 범위는 포함 (닫힘) 또는 배타 (개방) 일 수 있으며 상한이 없습니다.

11

static <C extends Comparable<?>> Range<C> encloseAll(Iterable<C> values)

주어진 모든 값을 포함하는 최소 범위를 반환합니다.

12

boolean encloses(Range<C> other)

other의 경계가이 범위의 경계를 벗어나지 않으면 true를 반환합니다.

13

boolean equals(Object object)

객체가이 범위와 동일한 끝점 및 바운드 유형을 갖는 범위이면 true를 반환합니다.

14

static <C extends Comparable<?>> Range<C> greaterThan(C endpoint)

끝점보다 엄격하게 큰 모든 값을 포함하는 범위를 반환합니다.

15

int hashCode()

이 범위에 대한 해시 코드를 반환합니다.

16

boolean hasLowerBound()

이 범위에 더 낮은 끝 점이 있으면 true를 반환합니다.

17

boolean hasUpperBound()

이 범위에 상위 끝 점이 있으면 true를 반환합니다.

18

Range<C> intersection(Range<C> connectedRange)

해당 범위가있는 경우이 범위와 connectedRange 모두로 묶인 최대 범위를 반환합니다.

19

boolean isConnected(Range<C> other)

이 범위와 다른 범위로 둘러싸인 범위 (비어있을 수 있음)가 있으면 true를 반환합니다.

20

boolean isEmpty()

이 범위가 [v..v) 또는 (v..v] 형식이면 true를 반환합니다.

21

static <C extends Comparable<?>> Range<C> lessThan(C endpoint)

끝점보다 엄격하게 작은 모든 값을 포함하는 범위를 반환합니다.

22

BoundType lowerBoundType()

이 범위의 하한 유형을 리턴합니다. 범위에 하한 엔드 포인트가 포함되면 BoundType.CLOSED, 그렇지 않으면 BoundType.OPEN.

23

C lowerEndpoint()

이 범위의 하위 끝점을 반환합니다.

24

static <C extends Comparable<?>> Range<C> open(C lower, C upper)

하한보다 크거나 상한보다 작은 모든 값을 포함하는 범위를 반환합니다.

25

static <C extends Comparable<?>> Range<C> openClosed(C lower, C upper)

하한보다 크거나 상한보다 작거나 같은 모든 값을 포함하는 범위를 반환합니다.

26

static <C extends Comparable<?>> Range<C> range(C lower, BoundType lowerType, C upper, BoundType upperType)

하한에서 상한까지의 값을 포함하는 범위를 반환합니다. 여기서 각 끝점은 포함 (닫힘) 또는 제외 (열림) 일 수 있습니다.

27

static <C extends Comparable<?>> Range<C> singleton(C value)

주어진 값만 포함하는 범위를 반환합니다.

28

Range<C> span(Range<C> other)

이 범위와 다른 범위를 모두 포함하는 최소 범위를 반환합니다.

29

String toString()

"[3..5)"와 같은이 범위의 문자열 표현을 반환합니다 (다른 예제는 클래스 문서에 나열되어 있음).

30

BoundType upperBoundType()

이 범위의 상한 유형을 리턴합니다. 범위에 상위 엔드 포인트가 포함되면 BoundType.CLOSED, 그렇지 않으면 BoundType.OPEN.

31

C upperEndpoint()

이 범위의 상위 끝점을 반환합니다.

32

static <C extends Comparable<?>> Range<C> upTo(C endpoint, BoundType boundType)

주어진 끝점까지 하한이없는 범위를 반환합니다. 범위는 포함 (닫힘) 또는 배타 (열림) 일 수 있습니다.

상속 된 메서드

이 클래스는 다음 클래스에서 메서드를 상속합니다-

  • java.lang.Object

범위 클래스의 예

원하는 편집기를 사용하여 다음 Java 프로그램을 만듭니다. C:/> Guava.

GuavaTester.java

import com.google.common.collect.ContiguousSet;
import com.google.common.collect.DiscreteDomain;
import com.google.common.collect.Range;
import com.google.common.primitives.Ints;

public class GuavaTester {

   public static void main(String args[]) {
      GuavaTester tester = new GuavaTester();
      tester.testRange();
   }

   private void testRange() {

      //create a range [a,b] = { x | a <= x <= b}
      Range<Integer> range1 = Range.closed(0, 9);	
      System.out.print("[0,9] : ");
      printRange(range1);		
      
      System.out.println("5 is present: " + range1.contains(5));
      System.out.println("(1,2,3) is present: " + range1.containsAll(Ints.asList(1, 2, 3)));
      System.out.println("Lower Bound: " + range1.lowerEndpoint());
      System.out.println("Upper Bound: " + range1.upperEndpoint());

      //create a range (a,b) = { x | a < x < b}
      Range<Integer> range2 = Range.open(0, 9);
      System.out.print("(0,9) : ");
      printRange(range2);

      //create a range (a,b] = { x | a < x <= b}
      Range<Integer> range3 = Range.openClosed(0, 9);
      System.out.print("(0,9] : ");
      printRange(range3);

      //create a range [a,b) = { x | a <= x < b}
      Range<Integer> range4 = Range.closedOpen(0, 9);
      System.out.print("[0,9) : ");
      printRange(range4);

      //create an open ended range (9, infinity
      Range<Integer> range5 = Range.greaterThan(9);
      System.out.println("(9,infinity) : ");
      System.out.println("Lower Bound: " + range5.lowerEndpoint());
      System.out.println("Upper Bound present: " + range5.hasUpperBound());

      Range<Integer> range6 = Range.closed(3, 5);	
      printRange(range6);

      //check a subrange [3,5] in [0,9]
      System.out.println("[0,9] encloses [3,5]:" + range1.encloses(range6));

      Range<Integer> range7 = Range.closed(9, 20);	
      printRange(range7);
      
      //check ranges to be connected		
      System.out.println("[0,9] is connected [9,20]:" + range1.isConnected(range7));
      Range<Integer> range8 = Range.closed(5, 15);	

      //intersection
      printRange(range1.intersection(range8));

      //span
      printRange(range1.span(range8));
   }

   private void printRange(Range<Integer> range) {		
   
      System.out.print("[ ");
      
      for(int grade : ContiguousSet.create(range, DiscreteDomain.integers())) {
         System.out.print(grade +" ");
      }
      System.out.println("]");
   }
}

결과 확인

다음을 사용하여 클래스 컴파일 javac 다음과 같이 컴파일러-

C:\Guava>javac GuavaTester.java

이제 GuavaTester를 실행하여 결과를 확인하십시오.

C:\Guava>java GuavaTester

결과를 확인하십시오.

[0,9] : [ 0 1 2 3 4 5 6 7 8 9 ]
5 is present: true
(1,2,3) is present: true
Lower Bound: 0
Upper Bound: 9
(0,9) : [ 1 2 3 4 5 6 7 8 ]
(0,9] : [ 1 2 3 4 5 6 7 8 9 ]
[0,9) : [ 0 1 2 3 4 5 6 7 8 ]
(9,infinity) : 
Lower Bound: 9
Upper Bound present: false
[ 3 4 5 ]
[0,9] encloses [3,5]:true
[ 9 10 11 12 13 14 15 16 17 18 19 20 ]
[0,9] is connected [9,20]:true
[ 5 6 7 8 9 ]
[ 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 ]