黑马程序员_day14 集合(迭代器,Vector中的枚举,LinkedList,HashSet)

---------------------- android培训、java培训 期待与您交流! ----------------------

一:集合类。

 1,为什么出现集合类? 答:面向对象语言度事物的体现都是以对象的形式,所以为了方便对多个对象的操作,就对
    对象进行存储,集合就是存储对象最常用的一种的方式。

 2,数组和集合类同时容器,有何不同? 答:数组虽然也可以存储对象但是长度是固定,但是集合石可变的,数组中
      可以存储基本数据类型,集合只能存储对象。

 3,集合类的特点:集合只用于存储对象,集合长度是可变的,集合可以存储不同类型的对象。

import java.util.*;

/*
Collection定义了集合框架的共性功能。
1,添加
 add(e);
 addAll(collection);

2,删除
 remove(e);
 removeAll(collection);
 clear();

3,判断。
 contains(e);
 isEmpty();

4,获取
 iterator();
 size();

5,获取交集。
 retainAll();

6,集合变数组。
 toArray();

 

1,add方法的参数类型是Object。以便于接收任意类型对象。

2,集合中存储的都是对象的引用(地址)


什么是迭代器呢?
其实就是集合的取出元素的方式。
如同抓娃娃游戏机中的夹子。

迭代器是取出方式,会直接访问集合中的元素。
所以将迭代器通过内部类的形式来进行描述。
通过容器的iterator()方法获取该内部类的对象。

 


*/
class  CollectionDemo
{
 public static void main(String[] args)
 {
  
  method_get();
 }
 public static void method_get()
 {
  ArrayList al = new ArrayList();

  //1,添加元素。
  al.add("java01");//add(Object obj);
  al.add("java02");
  al.add("java03");
  al.add("java04");

  /*
  Iterator it = al.iterator();//获取迭代器,用于取出集合中的元素。

  while(it.hasNext())
  {
   sop(it.next());
  }
  */

  for(Iterator it = al.iterator(); it.hasNext() ; )
  {
   sop(it.next());
  }
 }


 public static void method_2()
 {
  ArrayList al1 = new ArrayList();

  al1.add("java01");
  al1.add("java02");
  al1.add("java03");
  al1.add("java04");
  ArrayList al2 = new ArrayList();

  al2.add("java03");
  al2.add("java04");
  al2.add("java05");
  al2.add("java06");

  
  //al1.retainAll(al2);//去交集,al1中只会保留和al2中相同的元素。
  al1.removeAll(al2);

  sop("al1:"+al1);
  sop("al2:"+al2);

 


 }

 public static void base_method()
 {
  //创建一个集合容器。使用Collection接口的子类。ArrayList
  ArrayList al = new ArrayList();

  //1,添加元素。
  al.add("java01");//add(Object obj);
  al.add("java02");
  al.add("java03");
  al.add("java04");

  //打印原集合。
  sop("原集合:"+al);


  //3,删除元素。
  //al.remove("java02");
  //al.clear();//清空集合。


  //4,判断元素。
  sop("java03是否存在:"+al.contains("java03"));
  sop("集合是否为空?"+al.isEmpty());


  //2,获取个数。集合长度。
  sop("size:"+al.size());

  //打印改变后的集合。
  sop(al);

 }

 public static void sop(Object obj)
 {
  System.out.println(obj);
 }
}


二:ListDemo。

/*
Collection
 |--List:元素是有序的,元素可以重复。因为该集合体系有索引。
  |--ArrayList:底层的数据结构使用的是数组结构。特点:查询速度很快。但是增删稍慢。线程不同步。
  |--LinkedList:底层使用的链表数据结构。特点:增删速度很快,查询稍慢。线程不同步。
  |--Vector:底层是数组数据结构。线程同步。被ArrayList替代了。因为效率低。


 |--Set:元素是无序,元素不可以重复。、


List:
 特有方法。凡是可以操作角标的方法都是该体系特有的方法。


 add(index,element);
 addAll(index,Collection);


 remove(index);


 set(index,element);

 get(index):
 subList(from,to);
 listIterator();
 int indexOf(obj):获取指定元素的位置。
 ListIterator listIterator();

 

 

List集合特有的迭代器。ListIterator是Iterator的子接口。

在迭代时,不可以通过集合对象的方法操作集合中的元素。
因为会发生ConcurrentModificationException异常。

所以,在迭代器时,只能用迭代器的放过操作元素,可是Iterator方法是有限的,
只能对元素进行判断,取出,删除的操作,
如果想要其他的操作如添加,修改等,就需要使用其子接口,ListIterator。

该接口只能通过List集合的listIterator方法获取。

*/


import java.util.*;
class ListDemo
{
 public static void sop(Object obj)
 {
  System.out.println(obj);
 }
 public static void method()
 {
  
  ArrayList al = new ArrayList();

  //添加元素
  al.add("java01");
  al.add("java02");
  al.add("java03");
  
  sop("原集合是:"+al);
  //在指定位置添加元素。
  al.add(1,"java09");

  //删除指定位置的元素。
  //al.remove(2);

  //修改元素。
  //al.set(2,"java007");

  //通过角标获取元素。
  sop("get(1):"+al.get(1));

  sop(al);

  //获取所有元素。
  for(int x=0; x<al.size(); x++)
  {
   System.out.println("al("+x+")="+al.get(x));
  }

  Iterator it = al.iterator();

  while(it.hasNext())
  {
   sop("next:"+it.next());
  }


  //通过indexOf获取对象的位置。
  sop("index="+al.indexOf("java02"));

  List sub = al.subList(1,3);

  sop("sub="+sub);
 }

 
 public static void main(String[] args)
 {

  //演示列表迭代器。
  ArrayList al = new ArrayList();

  //添加元素
  al.add("java01");
  al.add("java02");
  al.add("java03");

  sop(al);

  
  ListIterator li = al.listIterator();

  
  //sop("hasPrevious():"+li.hasPrevious());

  while(li.hasNext())
  {
   Object obj = li.next();

   if(obj.equals("java02"))
    //li.add("java009");
    li.set("java006");


  }

  while(li.hasPrevious())
  {
   sop("pre::"+li.previous());
  }
  //sop("hasNext():"+li.hasNext());
  //sop("hasPrevious():"+li.hasPrevious());


  sop(al);

 

  /*
  //在迭代过程中,准备添加或者删除元素。

  Iterator it = al.iterator();

  while(it.hasNext())
  {
   Object obj = it.next();

   if(obj.equals("java02"))
    //al.add("java008");
    it.remove();//将java02的引用从集合中删除了。

   sop("obj="+obj);


  }
  sop(al);
  */
  


 }
}


三:Vector。


import java.util.*;

/*
枚举就是Vector特有的取出方式。
发现枚举和迭代器很像。
其实枚举和迭代是一样的。

因为枚举的名称以及方法的名称都过长。
所以被迭代器取代了。
枚举郁郁而终了。

 

*/
class VectorDemo
{
 public static void main(String[] args)
 {
  Vector v = new Vector();

  v.add("java01");
  v.add("java02");
  v.add("java03");
  v.add("java04");

  Enumeration en = v.elements();

  while(en.hasMoreElements())
  {
   System.out.println(en.nextElement());
  }
 }
}

 


四:LinkList。

import java.util.*;

/*
LinkedList:特有方法:
addFirst();
addLast();

getFirst();
getLast();
获取元素,但不删除元素。如果集合中没有元素,会出现NoSuchElementException

removeFirst();
removeLast();
获取元素,但是元素被删除。如果集合中没有元素,会出现NoSuchElementException


在JDK1.6出现了替代方法。

offerFirst();
offerLast();


peekFirst();
peekLast();
获取元素,但不删除元素。如果集合中没有元素,会返回null。

pollFirst();
pollLast();
获取元素,但是元素被删除。如果集合中没有元素,会返回null。

 


*/

class LinkedListDemo
{
 public static void main(String[] args)
 {
  LinkedList link = new LinkedList();

  link.addLast("java01");
  link.addLast("java02");
  link.addLast("java03");
  link.addLast("java04");

  //sop(link);
//  sop(link.getFirst());
//  sop(link.getFirst());
  //sop(link.getLast());
  //sop(link.removeFirst());
  //sop(link.removeFirst());

  //sop("size="+link.size());

  while(!link.isEmpty())
  {
   sop(link.removeLast());
  }

 }

 public static void sop(Object obj)
 {
  System.out.println(obj);
 }
}
/*

---
java01
java02
java03
java04

----
java04
java03
java02
java01
---
*/


五:ArrayListTest2。


import java.util.*;

/*
将自定义对象作为元素存到ArrayList集合中,并去除重复元素。

比如:存人对象。同姓名同年龄,视为同一个人。为重复元素。


思路:
1,对人描述,将数据封装进人对象。
2,定义容器,将人存入。
3,取出。

 

List集合判断元素是否相同,依据是元素的equals方法。

 

*/

 

class Person
{
 private String name;
 private int age;
 Person(String name,int age)
 {
  this.name = name;
  this.age = age;
 }
 
 public boolean equals(Object obj)
 {

  if(!(obj instanceof Person))
   return false;

  Person p = (Person)obj;
  //System.out.println(this.name+"....."+p.name);

  return this.name.equals(p.name) && this.age == p.age;
 }
 /**/
 public String getName()
 {
  return name;
 }
 public int getAge()
 {
  return age;
 }
}
class ArrayListTest2
{
 public static void sop(Object obj)
 {
  System.out.println(obj);
 }
 public static void main(String[] args)
 {
  ArrayList al = new ArrayList();

  al.add(new Demo());

  al.add(new Person("lisi01",30));//al.add(Object obj);//Object obj = new Person("lisi01",30);
  //al.add(new Person("lisi02",32));
  al.add(new Person("lisi02",32));
  al.add(new Person("lisi04",35));
  al.add(new Person("lisi03",33));
  //al.add(new Person("lisi04",35));

  
  //al = singleElement(al);

  sop("remove 03 :"+al.remove(new Person("lisi03",33)));//remove方法底层也是依赖于元素的equals方法。


  Iterator it = al.iterator();


  while(it.hasNext())
  {
   Person p = (Person)it.next();
   sop(p.getName()+"::"+p.getAge());
  }
 }


 public static ArrayList singleElement(ArrayList al)
 {
  //定义一个临时容器。
  ArrayList newAl = new ArrayList();

  Iterator it = al.iterator();

  while(it.hasNext())
  {
   Object obj = it.next();

   if(!newAl.contains(obj))
    newAl.add(obj);

  }

  return newAl;
 }
}


六:Set-->HashSet判断和删除的依据。

Set:元素师无序的(存入和取出的顺序不一定一致),元素是不可以重复。

HashSetTest 。


import java.util.*;

/*
往hashSet集合中存入自定对象
姓名和年龄相同为同一个人,重复元素。

 

 

*/
class HashSetTest
{
 public static void sop(Object obj)
 {
  System.out.println(obj);
 }
 public static void main(String[] args)
 {
  HashSet hs = new HashSet();

  hs.add(new Person("a1",11));
  hs.add(new Person("a2",12));
  hs.add(new Person("a3",13));
//  hs.add(new Person("a2",12));
//  hs.add(new Person("a4",14));

  //sop("a1:"+hs.contains(new Person("a2",12)));
   
//  hs.remove(new Person("a4",13));
  

  Iterator it = hs.iterator();

  while(it.hasNext())
  {
   Person p = (Person)it.next();
   sop(p.getName()+"::"+p.getAge());
  }
 }
}
class Person
{
 private String name;
 private int age;
 Person(String name,int age)
 {
  this.name = name;
  this.age = age;
 }
 
 public int hashCode()
 {
  System.out.println(this.name+"....hashCode");
  return name.hashCode()+age*37;
 }

 public boolean equals(Object obj)
 {

  if(!(obj instanceof Person))
   return false;

  Person p = (Person)obj;
  System.out.println(this.name+"...equals.."+p.name);

  return this.name.equals(p.name) && this.age == p.age;
 }

 
 public String getName()
 {
  return name;
 }
 public int getAge()
 {
  return age;
 }
}

---------------------- android培训、java培训 期待与您交流! ----------------------

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值