[LANG-1569] Add ArrayUtils.get(T[], index, T) to provide an
out-of-bounds default value
This commit is contained in:
parent
495167a392
commit
5b699d0765
|
@ -61,6 +61,7 @@ The <action> type attribute can be add,update,fix,remove.
|
||||||
<action issue="LANG-1545" type="update" dev="ggregory" due-to="XenoAmess, Gary Gregory">CharSequenceUtils.regionMatches is wrong dealing with Georgian.</action>
|
<action issue="LANG-1545" type="update" dev="ggregory" due-to="XenoAmess, Gary Gregory">CharSequenceUtils.regionMatches is wrong dealing with Georgian.</action>
|
||||||
<action type="add" dev="jochen">Added the Locks class as a convenient possibility to deal with locked objects.</action>
|
<action type="add" dev="jochen">Added the Locks class as a convenient possibility to deal with locked objects.</action>
|
||||||
<action issue="LANG-1568" type="add" dev="ggregory">Add to Functions: FailableBooleanSupplier, FailableIntSupplier, FailableLongSupplier, FailableDoubleSupplier, and so on.</action>
|
<action issue="LANG-1568" type="add" dev="ggregory">Add to Functions: FailableBooleanSupplier, FailableIntSupplier, FailableLongSupplier, FailableDoubleSupplier, and so on.</action>
|
||||||
|
<action issue="LANG-1569" type="add" dev="ggregory">Add ArrayUtils.get(T[], index, T) to provide an out-of-bounds default value.</action>
|
||||||
</release>
|
</release>
|
||||||
|
|
||||||
<release version="3.10" date="2020-03-22" description="New features and bug fixes. Requires Java 8, supports Java 9, 10, 11.">
|
<release version="3.10" date="2020-03-22" description="New features and bug fixes. Requires Java 8, supports Java 9, 10, 11.">
|
||||||
|
|
|
@ -1655,6 +1655,39 @@ public class ArrayUtils {
|
||||||
return Array.newInstance(newArrayComponentType, 1);
|
return Array.newInstance(newArrayComponentType, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the nTh element of an array or null if the index is out of bounds or the array is null.
|
||||||
|
*
|
||||||
|
* @param <T> The type of array elements.
|
||||||
|
* @param array The array to index.
|
||||||
|
* @param index The index
|
||||||
|
* @return the nTh element of an array or null if the index is out of bounds or the array is null.
|
||||||
|
* @since 3.11
|
||||||
|
*/
|
||||||
|
public static <T> T get(final T[] array, final int index) {
|
||||||
|
return get(array, index, null);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the nTh element of an array or a default value if the index is out of bounds.
|
||||||
|
*
|
||||||
|
* @param <T> The type of array elements.
|
||||||
|
* @param array The array to index.
|
||||||
|
* @param index The index
|
||||||
|
* @param defaultValue The return value of the given index is out of bounds.
|
||||||
|
* @return the nTh element of an array or a default value if the index is out of bounds.
|
||||||
|
* @since 3.11
|
||||||
|
*/
|
||||||
|
public static <T> T get(final T[] array, final int index, T defaultValue) {
|
||||||
|
if (array == null) {
|
||||||
|
return defaultValue;
|
||||||
|
}
|
||||||
|
if (index >= 0 && index < array.length) {
|
||||||
|
return array[index];
|
||||||
|
}
|
||||||
|
return defaultValue;
|
||||||
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
//-----------------------------------------------------------------------
|
||||||
/**
|
/**
|
||||||
* <p>Returns the length of the specified array.
|
* <p>Returns the length of the specified array.
|
||||||
|
|
|
@ -56,7 +56,6 @@ public class ArrayUtilsTest {
|
||||||
return ArrayUtils.toArray(items);
|
return ArrayUtils.toArray(items);
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
private void assertIsEquals(final Object array1, final Object array2, final Object array3) {
|
private void assertIsEquals(final Object array1, final Object array2, final Object array3) {
|
||||||
assertTrue(ArrayUtils.isEquals(array1, array1));
|
assertTrue(ArrayUtils.isEquals(array1, array1));
|
||||||
assertTrue(ArrayUtils.isEquals(array2, array2));
|
assertTrue(ArrayUtils.isEquals(array2, array2));
|
||||||
|
@ -69,7 +68,6 @@ public class ArrayUtilsTest {
|
||||||
assertFalse(ArrayUtils.isEquals(array2, array1));
|
assertFalse(ArrayUtils.isEquals(array2, array1));
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
/**
|
/**
|
||||||
* Tests generic array creation with parameters of same type.
|
* Tests generic array creation with parameters of same type.
|
||||||
*/
|
*/
|
||||||
|
@ -101,7 +99,6 @@ public class ArrayUtilsTest {
|
||||||
assertTrue(obj instanceof String[]);
|
assertTrue(obj instanceof String[]);
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
@Test
|
@Test
|
||||||
public void testClone() {
|
public void testClone() {
|
||||||
assertArrayEquals(null, ArrayUtils.clone((Object[]) null));
|
assertArrayEquals(null, ArrayUtils.clone((Object[]) null));
|
||||||
|
@ -192,7 +189,6 @@ public class ArrayUtilsTest {
|
||||||
assertNotSame(original, cloned);
|
assertNotSame(original, cloned);
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
@Test
|
@Test
|
||||||
public void testConstructor() {
|
public void testConstructor() {
|
||||||
assertNotNull(new ArrayUtils());
|
assertNotNull(new ArrayUtils());
|
||||||
|
@ -281,8 +277,6 @@ public class ArrayUtilsTest {
|
||||||
assertFalse(ArrayUtils.contains(array, (double) 99));
|
assertFalse(ArrayUtils.contains(array, (double) 99));
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
|
|
||||||
@SuppressWarnings("cast")
|
@SuppressWarnings("cast")
|
||||||
@Test
|
@Test
|
||||||
public void testContainsDoubleTolerance() {
|
public void testContainsDoubleTolerance() {
|
||||||
|
@ -363,7 +357,47 @@ public class ArrayUtilsTest {
|
||||||
assertEquals(0, array.length);
|
assertEquals(0, array.length);
|
||||||
}
|
}
|
||||||
|
|
||||||
// ------------------------------------------------------------------------
|
@Test
|
||||||
|
public void testGet() {
|
||||||
|
assertNull(ArrayUtils.get(null, -1));
|
||||||
|
assertNull(ArrayUtils.get(null, 0));
|
||||||
|
assertNull(ArrayUtils.get(null, 1));
|
||||||
|
final String[] array0 = {};
|
||||||
|
assertNull(ArrayUtils.get(array0, -1));
|
||||||
|
assertNull(ArrayUtils.get(array0, 0));
|
||||||
|
assertNull(ArrayUtils.get(array0, 1));
|
||||||
|
final String[] array1 = { StringUtils.EMPTY };
|
||||||
|
assertEquals(null, ArrayUtils.get(array1, -1));
|
||||||
|
assertEquals(StringUtils.EMPTY, ArrayUtils.get(array1, 0));
|
||||||
|
assertEquals(null, ArrayUtils.get(array1, 1));
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testGetDefault() {
|
||||||
|
// null default
|
||||||
|
{
|
||||||
|
assertNull(ArrayUtils.get(null, -1, null));
|
||||||
|
assertNull(ArrayUtils.get(null, 0, null));
|
||||||
|
assertNull(ArrayUtils.get(null, 1, null));
|
||||||
|
final String[] array0 = {};
|
||||||
|
assertNull(ArrayUtils.get(array0, -1, null));
|
||||||
|
assertNull(ArrayUtils.get(array0, 0, null));
|
||||||
|
assertNull(ArrayUtils.get(array0, 1, null));
|
||||||
|
final String[] array1 = { StringUtils.EMPTY };
|
||||||
|
assertEquals(null, ArrayUtils.get(array1, -1, null));
|
||||||
|
assertEquals(StringUtils.EMPTY, ArrayUtils.get(array1, 0, null));
|
||||||
|
assertEquals(null, ArrayUtils.get(array1, 1, null));
|
||||||
|
}
|
||||||
|
// non-null default
|
||||||
|
{
|
||||||
|
final String defaultValue = "defaultValue";
|
||||||
|
final String[] array1 = { StringUtils.EMPTY };
|
||||||
|
assertEquals(defaultValue, ArrayUtils.get(array1, -1, defaultValue));
|
||||||
|
assertEquals(StringUtils.EMPTY, ArrayUtils.get(array1, 0, defaultValue));
|
||||||
|
assertEquals(defaultValue, ArrayUtils.get(array1, 1, defaultValue));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testGetLength() {
|
public void testGetLength() {
|
||||||
assertEquals(0, ArrayUtils.getLength(null));
|
assertEquals(0, ArrayUtils.getLength(null));
|
||||||
|
@ -419,7 +453,6 @@ public class ArrayUtilsTest {
|
||||||
assertThrows(IllegalArgumentException.class, () -> ArrayUtils.getLength("notAnArray"));
|
assertThrows(IllegalArgumentException.class, () -> ArrayUtils.getLength("notAnArray"));
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
@Test
|
@Test
|
||||||
public void testHashCode() {
|
public void testHashCode() {
|
||||||
final long[][] array1 = new long[][]{{2, 5}, {4, 5}};
|
final long[][] array1 = new long[][]{{2, 5}, {4, 5}};
|
||||||
|
@ -885,7 +918,6 @@ public class ArrayUtilsTest {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
@Test
|
@Test
|
||||||
public void testIndexOf() {
|
public void testIndexOf() {
|
||||||
final Object[] array = new Object[]{"0", "1", "2", "3", null, "0"};
|
final Object[] array = new Object[]{"0", "1", "2", "3", null, "0"};
|
||||||
|
@ -900,7 +932,6 @@ public class ArrayUtilsTest {
|
||||||
assertEquals(-1, ArrayUtils.indexOf(array, "notInArray"));
|
assertEquals(-1, ArrayUtils.indexOf(array, "notInArray"));
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
@Test
|
@Test
|
||||||
public void testIndexOfBoolean() {
|
public void testIndexOfBoolean() {
|
||||||
boolean[] array = null;
|
boolean[] array = null;
|
||||||
|
@ -930,7 +961,6 @@ public class ArrayUtilsTest {
|
||||||
assertEquals(-1, ArrayUtils.indexOf(array, false, -1));
|
assertEquals(-1, ArrayUtils.indexOf(array, false, -1));
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
@Test
|
@Test
|
||||||
public void testIndexOfByte() {
|
public void testIndexOfByte() {
|
||||||
byte[] array = null;
|
byte[] array = null;
|
||||||
|
@ -957,7 +987,6 @@ public class ArrayUtilsTest {
|
||||||
assertEquals(-1, ArrayUtils.indexOf(array, (byte) 0, 6));
|
assertEquals(-1, ArrayUtils.indexOf(array, (byte) 0, 6));
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
@Test
|
@Test
|
||||||
public void testIndexOfChar() {
|
public void testIndexOfChar() {
|
||||||
char[] array = null;
|
char[] array = null;
|
||||||
|
@ -984,7 +1013,6 @@ public class ArrayUtilsTest {
|
||||||
assertEquals(-1, ArrayUtils.indexOf(array, 'a', 6));
|
assertEquals(-1, ArrayUtils.indexOf(array, 'a', 6));
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
@SuppressWarnings("cast")
|
@SuppressWarnings("cast")
|
||||||
@Test
|
@Test
|
||||||
public void testIndexOfDouble() {
|
public void testIndexOfDouble() {
|
||||||
|
@ -1049,7 +1077,6 @@ public class ArrayUtilsTest {
|
||||||
assertEquals(1, ArrayUtils.indexOf(array, 1.00001324, -300, 0.0001));
|
assertEquals(1, ArrayUtils.indexOf(array, 1.00001324, -300, 0.0001));
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
@SuppressWarnings("cast")
|
@SuppressWarnings("cast")
|
||||||
@Test
|
@Test
|
||||||
public void testIndexOfFloat() {
|
public void testIndexOfFloat() {
|
||||||
|
@ -1082,7 +1109,6 @@ public class ArrayUtilsTest {
|
||||||
assertEquals(-1, ArrayUtils.indexOf(array, (float) 0, 6));
|
assertEquals(-1, ArrayUtils.indexOf(array, (float) 0, 6));
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
@Test
|
@Test
|
||||||
public void testIndexOfInt() {
|
public void testIndexOfInt() {
|
||||||
int[] array = null;
|
int[] array = null;
|
||||||
|
@ -1109,7 +1135,6 @@ public class ArrayUtilsTest {
|
||||||
assertEquals(-1, ArrayUtils.indexOf(array, 0, 6));
|
assertEquals(-1, ArrayUtils.indexOf(array, 0, 6));
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
@Test
|
@Test
|
||||||
public void testIndexOfLong() {
|
public void testIndexOfLong() {
|
||||||
long[] array = null;
|
long[] array = null;
|
||||||
|
@ -1136,7 +1161,6 @@ public class ArrayUtilsTest {
|
||||||
assertEquals(-1, ArrayUtils.indexOf(array, 0, 6));
|
assertEquals(-1, ArrayUtils.indexOf(array, 0, 6));
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
@Test
|
@Test
|
||||||
public void testIndexOfShort() {
|
public void testIndexOfShort() {
|
||||||
short[] array = null;
|
short[] array = null;
|
||||||
|
@ -1505,8 +1529,6 @@ public class ArrayUtilsTest {
|
||||||
assertFalse(ArrayUtils.isSorted(array));
|
assertFalse(ArrayUtils.isSorted(array));
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testIsSortedFloat() {
|
public void testIsSortedFloat() {
|
||||||
float[] array = null;
|
float[] array = null;
|
||||||
|
@ -2249,7 +2271,6 @@ public class ArrayUtilsTest {
|
||||||
assertArrayEquals(ArrayUtils.EMPTY_STRING_ARRAY, ArrayUtils.nullToEmpty((String[]) null));
|
assertArrayEquals(ArrayUtils.EMPTY_STRING_ARRAY, ArrayUtils.nullToEmpty((String[]) null));
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
@Test
|
@Test
|
||||||
public void testReverse() {
|
public void testReverse() {
|
||||||
final StringBuffer str1 = new StringBuffer("pick");
|
final StringBuffer str1 = new StringBuffer("pick");
|
||||||
|
@ -2667,7 +2688,6 @@ public class ArrayUtilsTest {
|
||||||
assertNull(array);
|
assertNull(array);
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
@Test
|
@Test
|
||||||
public void testSameLength() {
|
public void testSameLength() {
|
||||||
final Object[] nullArray = null;
|
final Object[] nullArray = null;
|
||||||
|
@ -4256,7 +4276,6 @@ public class ArrayUtilsTest {
|
||||||
assertTrue(ArrayUtils.isSameLength(twoArray, twoArray));
|
assertTrue(ArrayUtils.isSameLength(twoArray, twoArray));
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
@Test
|
@Test
|
||||||
public void testSameType() {
|
public void testSameType() {
|
||||||
assertThrows(IllegalArgumentException.class, () -> ArrayUtils.isSameType(null, null));
|
assertThrows(IllegalArgumentException.class, () -> ArrayUtils.isSameType(null, null));
|
||||||
|
@ -4469,7 +4488,6 @@ public class ArrayUtilsTest {
|
||||||
assertEquals(2, array[3]);
|
assertEquals(2, array[3]);
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
@Test
|
@Test
|
||||||
public void testShiftDouble() {
|
public void testShiftDouble() {
|
||||||
final double[] array = new double[]{1, 2, 3, 4};
|
final double[] array = new double[]{1, 2, 3, 4};
|
||||||
|
@ -5545,7 +5563,6 @@ public class ArrayUtilsTest {
|
||||||
assertEquals(3, array[2]);
|
assertEquals(3, array[2]);
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
@Test
|
@Test
|
||||||
public void testSwapChar() {
|
public void testSwapChar() {
|
||||||
char[] array = new char[]{1, 2, 3};
|
char[] array = new char[]{1, 2, 3};
|
||||||
|
@ -6034,7 +6051,6 @@ public class ArrayUtilsTest {
|
||||||
assertEquals(3, array[2]);
|
assertEquals(3, array[2]);
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
@Test
|
@Test
|
||||||
public void testToMap() {
|
public void testToMap() {
|
||||||
Map<?, ?> map = ArrayUtils.toMap(new String[][]{{"foo", "bar"}, {"hello", "world"}});
|
Map<?, ?> map = ArrayUtils.toMap(new String[][]{{"foo", "bar"}, {"hello", "world"}});
|
||||||
|
@ -6090,8 +6106,6 @@ public class ArrayUtilsTest {
|
||||||
assertEquals(Collections.singletonMap("key", "value1"), map);
|
assertEquals(Collections.singletonMap("key", "value1"), map);
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testToObject_boolean() {
|
public void testToObject_boolean() {
|
||||||
final boolean[] b = null;
|
final boolean[] b = null;
|
||||||
|
@ -6447,7 +6461,6 @@ public class ArrayUtilsTest {
|
||||||
Short.valueOf((short) 9999999)}, Short.MAX_VALUE));
|
Short.valueOf((short) 9999999)}, Short.MAX_VALUE));
|
||||||
}
|
}
|
||||||
|
|
||||||
//-----------------------------------------------------------------------
|
|
||||||
@Test
|
@Test
|
||||||
public void testToString() {
|
public void testToString() {
|
||||||
assertEquals("{}", ArrayUtils.toString(null));
|
assertEquals("{}", ArrayUtils.toString(null));
|
||||||
|
|
Loading…
Reference in New Issue