有很多方法可以找到数组中某个值的位置。
以下示例片段都假定数组是以下之一:
String[] strings = new String[] { "A", "B", "C" };
int[] ints = new int[] { 1, 2, 3, 4 };
此外,每个都将 index 或者 index2 设置为所需元素的索引,如果该元素不存在,则为 -1.
使用 Arrays.binarySearch(仅用于排序数组)
int index = Arrays.binarySearch(strings, "A"); int index2 = Arrays.binarySearch(ints, 1);
使用 Arrays.asList(仅适用于非原始数组)
int index = Arrays.asList(strings).indexOf("A");
int index2 = Arrays.asList(ints).indexOf(1); //compilation error
使用流
适用于版本 ≥ Java SE 8
int index = IntStream.range(0, strings.length)
.filter(i -> "A".equals(strings[i]))
.findFirst()
.orElse(-1); //If not present, gives us -1.
//Similar for an array of primitives
使用循环进行线性搜索
int index = -1;
for (int i = 0; i < array.length; i++) {
if ("A".equals(array[i])) {
index = i;
break;
}
}
//Similar for an array of primitives
使用 org.apache.commons 等 第三方库进行线性搜索
int index = org.apache.commons.lang3.ArrayUtils.contains(strings, "A"); int index2 = org.apache.commons.lang3.ArrayUtils.contains(ints, 1);
日期:2020-06-02 22:15:17 来源:oir作者:oir
