If you must work with raw arrays and not ArrayList then Arrays has what you need. If you look at the source code, these are the absolutely best ways to get a copy of an array. They do have a good bit of defensive programming because the System.arraycopy() method throws lots of unchecked exceptions if you feed it illogical parameters.
You can use either Arrays.copyOf() which will copy from the first to Nth element to the new shorter array.
public static <T> T[] copyOf(T[] original, int newLength)
Copies the specified array, truncating or padding with nulls (if
  necessary) so the copy has the specified length. For all indices that
  are valid in both the original array and the copy, the two arrays will
  contain identical values. For any indices that are valid in the copy
  but not the original, the copy will contain null. Such indices will
  exist if and only if the specified length is greater than that of the
  original array. The resulting array is of exactly the same class as
  the original array.
2770
2771    public static <T,U> T[] More ...copyOf(U[] original, int newLength, Class<? extends T[]> newType) {
2772        T[] copy = ((Object)newType == (Object)Object[].class)
2773            ? (T[]) new Object[newLength]
2774            : (T[]) Array.newInstance(newType.getComponentType(), newLength);
2775        System.arraycopy(original, 0, copy, 0,
2776                         Math.min(original.length, newLength));
2777        return copy;
2778    }
or Arrays.copyOfRange() will also do the trick:
public static <T> T[] copyOfRange(T[] original, int from, int to)
Copies the specified range of the specified array into a new array.
  The initial index of the range (from) must lie between zero and
  original.length, inclusive. The value at original[from] is placed into
  the initial element of the copy (unless from == original.length or
  from == to). Values from subsequent elements in the original array are
  placed into subsequent elements in the copy. The final index of the
  range (to), which must be greater than or equal to from, may be
  greater than original.length, in which case null is placed in all
  elements of the copy whose index is greater than or equal to
  original.length - from. The length of the returned array will be to -
  from. The resulting array is of exactly the same class as the original
  array.
3035    public static <T,U> T[] More ...copyOfRange(U[] original, int from, int to, Class<? extends T[]> newType) {
3036        int newLength = to - from;
3037        if (newLength < 0)
3038            throw new IllegalArgumentException(from + " > " + to);
3039        T[] copy = ((Object)newType == (Object)Object[].class)
3040            ? (T[]) new Object[newLength]
3041            : (T[]) Array.newInstance(newType.getComponentType(), newLength);
3042        System.arraycopy(original, from, copy, 0,
3043                         Math.min(original.length - from, newLength));
3044        return copy;
3045    }
As you can see, both of these are just wrapper functions over System.arraycopy with defensive logic that what you are trying to do is valid.
System.arraycopy is the absolute fastest way to copy arrays.