如何从java中的字符串数组中删除特定值?

Vic*_*cky 6 java

可能重复:
从数组中删除元素(Java)

例如,如何删除特定的String数组值

String[] str_array = {"item1","item2","item3"};

我想从str_array中删除"item2"请帮助我,我希望输出像

String[] str_array = {"item1","item3"};

Vik*_*dor 25

我会这样做:

String[] str_array = {"item1","item2","item3"};
List<String> list = new ArrayList<String>(Arrays.asList(str_array));
list.remove("item2");
str_array = list.toArray(new String[0]);
Run Code Online (Sandbox Code Playgroud)

  • 与使用`System.arraycopy`相比效率低,特别是多次使用时. (3认同)

FTh*_*son 7

如果必须使用数组,System.arraycopy则是最有效,可扩展的解决方案.但是,如果必须多次从数组中删除一个元素,则应使用List的实现而不是数组.

以下System.arraycopy用于实现期望的效果.

public static Object[] remove(Object[] array, Object element) {
    if (array.length > 0) {
        int index = -1;
        for (int i = 0; i < array.length; i++) {
            if (array[i].equals(element)) {
                index = i;
                break;
            }
        }
        if (index >= 0) {
            Object[] copy = (Object[]) Array.newInstance(array.getClass()
                    .getComponentType(), array.length - 1);
            if (copy.length > 0) {
                System.arraycopy(array, 0, copy, 0, index);
                System.arraycopy(array, index + 1, copy, index, copy.length - index);
            }
            return copy;
        }
    }
    return array;
}
Run Code Online (Sandbox Code Playgroud)

此外,如果您知道阵列仅包含Comparable对象,则可以提高方法的效率.您可以Arrays.sort在将它们传递给remove方法之前对它们进行排序,修改后用于Arrays.binarySearch查找索引而不是for循环,将方法效率的该部分从O(n)提高到O(nlogn).

  • 确实.此外,如果代码的这一部分成为瓶颈,那么数组可能不是您程序最合适的数据结构. (2认同)

Sum*_*ngh 6

您可以使用ArrayUtils API删除它。

array = ArrayUtils.removeElement(array, element);
Run Code Online (Sandbox Code Playgroud)