Jambu Biji - Kelas Prekondisi

Prasyarat menyediakan metode statis untuk memeriksa apakah metode atau konstruktor dipanggil dengan parameter yang tepat atau tidak. Ia memeriksa prasyarat. Metodenya memunculkan IllegalArgumentException jika gagal.

Deklarasi Kelas

Berikut adalah deklarasi untuk com.google.common.base.Preconditions kelas -

@GwtCompatible
public final class Preconditions
   extends Object

Metode Kelas

Sr Tidak Metode & Deskripsi
1

static void checkArgument(boolean expression)

Memastikan kebenaran ekspresi yang melibatkan satu atau lebih parameter ke metode pemanggilan.

2

static void checkArgument(boolean expression, Object errorMessage)

Memastikan kebenaran ekspresi yang melibatkan satu atau lebih parameter ke metode pemanggilan.

3

static void checkArgument(boolean expression, String errorMessageTemplate, Object. errorMessageArgs)

Memastikan kebenaran ekspresi yang melibatkan satu atau lebih parameter ke metode pemanggilan.

4

static int checkElementIndex(int index, int size)

Memastikan bahwa indeks menentukan elemen yang valid dalam larik, daftar, atau rangkaian ukuran.

5

static int checkElementIndex(int index, int size, String desc)

Memastikan bahwa indeks menentukan elemen yang valid dalam larik, daftar, atau ukuran string.

6

static <T> T checkNotNull(T reference)

Memastikan bahwa referensi objek yang diteruskan sebagai parameter ke metode panggilan tidak null.

7

static <T> T checkNotNull(T reference, Object errorMessage)

Memastikan bahwa referensi objek yang diteruskan sebagai parameter ke metode panggilan tidak null.

8

static <T> T checkNotNull(T reference, String errorMessageTemplate, Object... errorMessageArgs)

Memastikan bahwa referensi objek yang diteruskan sebagai parameter ke metode panggilan tidak null.

9

static int checkPositionIndex(int index, int size)

Memastikan bahwa indeks menentukan posisi yang valid dalam larik, daftar, atau rangkaian ukuran.

10

static int checkPositionIndex(int index, int size, String desc)

Memastikan bahwa indeks menentukan posisi yang valid dalam larik, daftar, atau rangkaian ukuran.

11

static void checkPositionIndexes(int start, int end, int size)

Memastikan bahwa awal dan akhir menentukan posisi yang valid dalam larik, daftar atau ukuran string, dan dalam urutan.

12

static void checkState(boolean expression)

Memastikan kebenaran ekspresi yang melibatkan status instance pemanggil, tetapi tidak melibatkan parameter apa pun ke metode pemanggilan.

13

static void checkState(boolean expression, Object errorMessage)

Memastikan kebenaran ekspresi yang melibatkan status instance pemanggil, tetapi tidak melibatkan parameter apa pun ke metode pemanggilan.

14

static void checkState(boolean expression, String errorMessageTemplate, Object... errorMessageArgs)

Memastikan kebenaran ekspresi yang melibatkan status instance pemanggil, tetapi tidak melibatkan parameter apa pun ke metode pemanggilan.

Metode yang Diwarisi

Kelas ini mewarisi metode dari kelas berikut -

  • java.lang.Object

Contoh Kelas Prekondisi

Buat program java berikut menggunakan editor pilihan Anda di katakan C:/> Guava.

GuavaTester.java

import com.google.common.base.Preconditions;

public class GuavaTester {

   public static void main(String args[]) {
      GuavaTester guavaTester = new GuavaTester();

      try {
         System.out.println(guavaTester.sqrt(-3.0));
      } catch(IllegalArgumentException e) {
         System.out.println(e.getMessage());
      }

      try {
         System.out.println(guavaTester.sum(null,3));
      } catch(NullPointerException e) {
         System.out.println(e.getMessage());
      }

      try {
         System.out.println(guavaTester.getValue(6));
      } catch(IndexOutOfBoundsException e) {
         System.out.println(e.getMessage());
      }
   }

   public double sqrt(double input) throws IllegalArgumentException {
      Preconditions.checkArgument(input > 0.0,
         "Illegal Argument passed: Negative value %s.", input);
      return Math.sqrt(input);
   }

   public int sum(Integer a, Integer b) {
      a = Preconditions.checkNotNull(a, "Illegal Argument passed: First parameter is Null.");
      b = Preconditions.checkNotNull(b, "Illegal Argument passed: Second parameter is Null.");

      return a+b;
   }

   public int getValue(int input) {
      int[] data = {1,2,3,4,5};
      Preconditions.checkElementIndex(input,data.length, "Illegal Argument passed: Invalid index.");
      return 0;
   }
}

Verifikasi Hasilnya

Kompilasi kelas menggunakan javac kompiler sebagai berikut -

C:\Guava>javac GuavaTester.java

Sekarang jalankan GuavaTester untuk melihat hasilnya.

C:\Guava>java GuavaTester

Lihat hasilnya.

Illegal Argument passed: Negative value -3.0.
Illegal Argument passed: First parameter is Null.
Illegal Argument passed: Invalid index. (6) must be less than size (5)