List子接口
有序、有下标、元素可重复
1、方法
- extends Collection<> //继承Collection的方法
- void add(int index ,Object o) //在index位置插入对象o;
- boolean addAll(int index ,Collection c) //将一个集合中的元素添加到此集合中的index位置
- Object get (int Index ) //返回集合中指定位置的元素
- List subList (int fromIndex,int toIndex) //返回fromIndex和toIndex之间的集合元素
- int indexod(Object o) //返回此列表中第一次出现的指定元素的索引;如果此列表不包含该元素,则返回-1;
- set (in index,E element) //用指定元素替换列表中的指定位置的元素
2、List接口的使用
List list =new ArrayList<>();
list.add("苹果");
list.add(1,"榴莲");
list.add(0,"香蕉");
System.out.println(list.toString());
list.remove("苹果");
for (int i = 0; i < list.size(); i++) {
System.out.println(list.get(i));
}
for (Object s:list
) {
System.out.println(s);
}
Iterator it =list.iterator();
while(it.hasNext()){
System.out.println(it.next());
}
ListIterator lit =list.listIterator();
lit.add("车厘子");
while (lit.hasNext()){
System.out.println(lit.nextIndex()+":"+lit.next());
}
while(lit.hasPrevious()){
System.out.println(lit.previousIndex()+":"+lit.previous());
}
System.out.println(list.contains("车厘子"));
System.out.println(list.isEmpty());
System.out.println(list.indexOf("车厘子"));
3、List实现类
-
ArrayList
-
数组结构实现,查询快,增删慢; -
jdk1.2版本,运行效率快、线程不安全; -
ArrayList的使用:
-
public static void main(String[] args) {
ArrayList arrayList = new ArrayList<>();
Person person1 = new Person("马龙", 33, "男");
Person person2 = new Person("张继科", 25, "男");
arrayList.add(person1);
arrayList.add(person2);
System.out.println(arrayList);
System.out.println(arrayList.size());
Iterator lt = arrayList.listIterator();
while (lt.hasNext()) {
Person p = (Person) lt.next();
System.out.println(p.toString());
}
ListIterator lit = arrayList.listIterator();
while (lit.hasNext()) {
Person p = (Person) lit.next();
System.out.println(p.toString());
}
while (lit.hasPrevious()) {
Person p = (Person) lit.previous();
System.out.println(p.toString());
}
System.out.println(arrayList.contains(new Person("张继科",25,"男")));
System.out.println(arrayList.indexOf(new Person("张继科",25,"男")));
}
-
public class Person {
private String name;
private int age;
private String sex;
public Person(String name, int age, String sex) {
this.name = name;
this.age = age;
this.sex = sex;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
@Override
public String toString() {
return "Person{" +
"name='" + name + '\'' +
", age=" + age +
", sex='" + sex + '\'' +
'}';
}
@Override
public boolean equals(Object obj) {
if(this==obj){
return true;
}
if (obj==null){
return false;
}
if(obj instanceof Person){
Person p=(Person)obj;
if(this.name==p.name&&this.age==p.age&&this.sex==p.sex){
return true;
}
}
return false;
}
-
Vector
-
数组结构实现,查询快,增删慢; -
jdk1.0版本,运行效率慢,线程安全; -
Vector的使用:
Vector vector =new Vector<>();
vector.add("苹果");
vector.add("香蕉");
vector.add("芒果");
Enumeration en = vector.elements();
while (en.hasMoreElements()){
String s =(String)en.nextElement();
System.out.println(s);
}
System.out.println(vector.firstElement());
System.out.println(vector.lastElement());
System.out.println(vector.elementAt(1));
-
LinkedList
-
链表结构实现,增删快,查询慢 -
LinkedList的使用:
LinkedList ll = new LinkedList<>();
Person person1 = new Person("马龙", 33, "男");
Person person2 = new Person("张继科", 25, "男");
ll.add(person1);
ll.add(person2);
System.out.println(ll.toString());
for (int i = 0; i < ll.size(); i++) {
System.out.println(ll.get(i));
}
for (Object obj : ll) {
System.out.println(obj);
}
Iterator it = ll.iterator();
while (it.hasNext()){
System.out.println(it.next());
}
System.out.println("逆序遍历");
ListIterator lit =ll.listIterator(ll.size());
while (lit.hasPrevious()){
Person p =(Person)lit.previous();
System.out.println(p.toString());
}
-
ArrayList与LinkedList的区别:
- ArrayList是数组结构,必须开辟连续空间,查询快,增删慢
- LinkedList是双向链表结构,无需开辟连续空间,查询慢,增删快
|