ArrayList类:实现了可变数组,允许保存所有元素,包括null并可以根据索引位置对集合进行快速访问和随机访问
缺点:向指引的索引位置插入对象或删除对象比较慢
ArrayList和Vcetor的区别
一,同步性
Vector是同步的 这个类中的一些方法保证了Vector中的对象是线程安全的 而ArrayList中的对象并不是线程安全的
二,数据增长
从内部实现机制讲ArrayList和Vector都是使用数组(Array)来控制集合中的对象,当向这两种类型中增加元素的时候
如果元素的数目超出的内部数组的目前长度都需要进行扩展内部数组的长度 Vector缺省情况下自动增长为原来的一杯的数组长度ArrayList
是原来的50%所以当需要在集合中加入大量数据则选用Vector具有优势
HashMap和Hashtable的区别
一:Hashtable是基于陈旧的Dictionary的类 HashMap是基于JAVA 1.2引进的Mao接口的一个实现
二:同步性:Hashtable是同步的 这个类中的一些方法保证了Hashtable中的线程是安全的而HashMap
是异步的,此中的对象并不是线程安全的,若不需要保证线程安全HashMap优先选用
三:值:HashMap中可以将空值作为一个表的条目和Key或value
但是Hashtable不能放入空值(null)
1:如果要求线程安全 用Vector Hashtable
2:如果不要求线程安全 应该使用ArrayList,LinkedList HashMap
3:如果要求 键值对 使用HashMap Hashtable
4:如果数据量很大 同时线程安全 Vector
System.exit(0)
System.exit(-1) exit(终止java当前运行的虚拟机)
非零状态表示异常终止
LinkedList中
.addFirst();方法 加入至第一个
.addLast();方法 加入至最后一个
Map结构的集合类
HashMap Hashtable
缺点:向指引的索引位置插入对象或删除对象比较慢
ArrayList和Vcetor的区别
一,同步性
Vector是同步的 这个类中的一些方法保证了Vector中的对象是线程安全的 而ArrayList中的对象并不是线程安全的
二,数据增长
从内部实现机制讲ArrayList和Vector都是使用数组(Array)来控制集合中的对象,当向这两种类型中增加元素的时候
如果元素的数目超出的内部数组的目前长度都需要进行扩展内部数组的长度 Vector缺省情况下自动增长为原来的一杯的数组长度ArrayList
是原来的50%所以当需要在集合中加入大量数据则选用Vector具有优势
HashMap和Hashtable的区别
一:Hashtable是基于陈旧的Dictionary的类 HashMap是基于JAVA 1.2引进的Mao接口的一个实现
二:同步性:Hashtable是同步的 这个类中的一些方法保证了Hashtable中的线程是安全的而HashMap
是异步的,此中的对象并不是线程安全的,若不需要保证线程安全HashMap优先选用
三:值:HashMap中可以将空值作为一个表的条目和Key或value
但是Hashtable不能放入空值(null)
1:如果要求线程安全 用Vector Hashtable
2:如果不要求线程安全 应该使用ArrayList,LinkedList HashMap
3:如果要求 键值对 使用HashMap Hashtable
4:如果数据量很大 同时线程安全 Vector
System.exit(0)
System.exit(-1) exit(终止java当前运行的虚拟机)
非零状态表示异常终止
LinkedList中
.addFirst();方法 加入至第一个
.addLast();方法 加入至最后一个
Map结构的集合类
HashMap Hashtable
package lei;
import java.util.*;
public class Demo {
public static void main(String[] args) {
// TODO Auto-generated method stub
HashMap hm=new HashMap();
Emp emp0 = new Emp("01", "aaa", 111);
Emp emp1 = new Emp("02", "bbb", 222);
Emp emp2 = new Emp("03", "ccc", 333);
hm.put("01", emp0);
hm.put("02",emp1);
hm.put("02",emp2); //后者会自动覆盖前者
if(hm.containsKey("02")) { //查找编号为"02"
System.out.println("找到该员工");
Emp emp = (Emp)hm.get("02");
//键值对 key--value
System.out.println("名字为"+emp.getName());
}else{
System.out.println("未找到该员工");
}
//遍历HashMap中所有的key和value
Iterator it =hm.keySet().iterator();//创建迭代器
while(it.hasNext()){ //判断是否有下一个
String key=it.next().toString(); //取出Key 转化为String格式
Emp emp=(Emp)hm.get(key); //通过key 取出emp
System.out.println("名字是"+emp.getName());
System.out.println("薪水是"+emp.getSal()); //取出顺序不稳定的
}
}
}<pre name="code" class="java">class Emp{
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getEmpno() {
return Empno;
}
public void setEmpne(String empne) {
Empno = empne;
}
public float getSal() {
return sal;
}
public void setSal(float sal) {
this.sal = sal;
}
private String name;
private String Empno;
private float sal;
public Emp(String name , String Empno,float sal){
this.name=name;
this.sal=sal;
this.Empno=Empno;
}
}
本文深入探讨了Java中ArrayList, Vector, HashMap及Hashtable的特点与区别,并提供了实用代码示例,帮助理解不同集合类型的适用场景。
1003

被折叠的 条评论
为什么被折叠?



