关于ArrayList的初始化和删除的总结
转载自我的CSDN:https://blog.csdn.net/pH2002/article/details/130851820?spm=1001.2014.3001.5501
只删除一个元素
直接总结:
初始化要用Arrays.asList(1,2,3,4,5); 然后再作为参数进入array.addAll()函数里
这样就不用调用add函数一个个加了
关于删除,有三种写法是正确的
第一种是
int n=array.size();
for(int i=0;i<n-1;i++){
如果要提出来,则索引要搞一个n-1
第二种是
for(int i=0;i<array.size();i++){
因为array.size()会默认减少1,而且整个数组会往前移动一位
但是我突然发现这样会有一个弊端, 如果是要删除3,并且连续两个元素都是3,则是删不掉的。
第三种是迭代器,不常用。
iter.remove();
public class Solution {
public static void main(String[] args) {
List<Integer> array1=Arrays.asList(1,2,3,4,5);
ArrayList<Integer> array=new ArrayList<>();
array.addAll(array1);
//方法一,把N提出来,for循环写n-1
/*
int n=array.size();
for(int i=0;i<n-1;i++){
if(array.get(i)==3) array.remove(i);
System.out.println(array.get(i));
}
*/
//方法2,如果不提n,默认的array.size()会减1,且数组会自动补充进前面的位置。所以也不会报错
/*
for(int i=0;i<array.size();i++){
if(array.get(i)==3) array.remove(i);
System.out.println(array.get(i));
}
*/
//会报错,ConcurrentModificationException,源码级别的错误
/*
for(int j:array){
if(j==3){
array.remove((Integer)j);
}
System.out.println(j);
}
*/
//也是报上面的错误,因为都是迭代器
/*
Iterator iter=array.iterator();
while(iter.hasNext()){
Object next = iter.next();
int num=(int)next;
if(num==3){
array.remove((Integer)3);
}
}
*/
//方法3,使用迭代器删除元素,要用iter.remove()
Iterator iter=array.iterator();
while(iter.hasNext()){
Object next = iter.next();
int num=(int)next;
if(num==3){
iter.remove();
}
}
for(int i=0;i<array.size();i++){
System.out.println(array.get(i));
}
}
}
可能删除多个元素
针对于多个元素,要用i- -回调一下索引。
List<Integer> array1=Arrays.asList(1,2,3,3,4,5);
ArrayList<Integer> array=new ArrayList<>();
array.addAll(array1);
//方法2,如果不提n,默认的array.size()会减1,且数组会自动补充进前面的位置。所以也不会报错
for(int i=0;i<array.size();i++){
if(array.get(i)==3) {
array.remove(i);
i--;
}
System.out.println(array.get(i));
//输出为[1,2,2,2,4,5]不过array里面最终会是[1,2,4,5]
}