JAVA编程题递归遍历D盘下的所有文件夹和文件
package esystem;import java.io.File;public class Dir { public static void main(String[] args) { File d = new File("D:\\"); Dir (d); } public static void Dir(File dir) { if (dir.exists()) { for (File f : dir.listFiles()) { if (f.isDirectory()) { System.out.println("DIR: " + f.getName()); Dir(f); } else { System.out.println(" File: " + f.getName()); } } } }}
java中foreach和迭代器在遍历List集合,一些情况下为什么能使用集合自动的删除方法删除元素
你a<70的时候是倒数第二位,也就是66,没有抛出异常是因为之前list大小为5,你删除66后,list大小为4,你第一次遍历list大小为5的数组的时候,66的cursor在index = 4,当你删除后,遍历list大小为4的数组时, cursor = 4 = newlist.size()。
ArrayList里的这个方法就会判断list已经读取完毕了,所以不会抛出异常。
1
2
3
public boolean hasNext() {
return cursor != size;
}
a < 90的时候在第二位就发生了变化,list的大小也发生了变化
看了下ArrayList的源码,每次循环的时候都会call这个方法检查list的大小是否发生了变化,但是这个方法是发生在hasNext方法之后的
1
2
3
4
final void checkForComodification() {
if (modCount != expectedModCount)
throw new ConcurrentModificationException();
}
java中什么叫集合
java中集合包含:List、Set、Map、工具类Collections
List 包含以下子类
1.ArrayList
内部动态数组的实现,添加的时候有序,按照index遍历也是有序的,线程不安全类。
2.LinkedList
是一个继承于AbstractSequentialList的双向链表。它可以被当成堆栈、队列或双端队列进行操作。实现了List接口,能对它进行队列操作。实现了Deque接口,能当作双端队列使用。实现了Cloneable接口,覆盖了clone(),能克隆。实现了java.io.Serializable接口,这意味着LinkedList支持序列化,能通过序列化去传输。可以保持插入时的顺序
3. ArrayList 和 LinkedList区别
是一个数组队列,相当于动态数组。它由数组实现,随机访问效率高,随机插入、随机删除效率低。是一个双向链表。它也可以被当作堆栈、队列或双端队列进行操作。LinkedList随机访问效率低,但随机插入、随机删除效率低。
4.CopyOnWriteArrayList
线程安全的List,写 时复制,写加锁,复制一个容器,读不加锁。
5.Vector
线程安全类,数组实现。读加锁,写加锁,性能低。

