面试题-Date:2021-03-03
1.ArrayList和LinkedList
1.1ArrayList和LinkedList有什么区别?如何选用?
- 就一次性的通过add从集合尾部添加元素后只需读取一次建议永ArrayList
- 如果要频繁的添加元素,或在完成添加后会频繁通过indexOf方法从集合里查找元素,建议永LinkedList
1.2ArrayList和LinkedList哪个是线程不安全的,哪个是线程安全的
ArrayList和LinkedList线程不安全,Vector线程安全
1.3ArrayList满了以后如何扩容
扩容时,ArrayList是扩容50%,Vector是100%
LinkedList是双向连表无需扩容
1.4Vector你还用吗?(其实很多项目里不用了)
Vector使用概率很少
1.5如何遍历?便利是能否修改(其实是fail-fast问题)
import java.util.ArrayList;
import java.util.List;
public class VisitError {
public static void main(String[] args) {
List<String> strList = new ArrayList<String>();
strList.add("1");
strList.add("2");
strList.add("3");
strList.add("4");
//correct
for(int i = 0;i<strList.size();i++){
System.out.println(strList.get(i));
}
//throw Exception
for(String str:strList){
System.out.println(str);
if("2".equals(str) ) {
strList.remove("2");
}