黑马程序员---集合框架(一)
来源:互联网 发布:中国历史延续 知乎 编辑:程序博客网 时间:2024/04/30 08:40
------<a href="http://www.itheima.com" target="blank">Java培训、Android培训、iOS培训、.Net培训</a>、期待与您交流! -------
一、集合框架概述
为什么会出现集合类:面向对象语言对事物 的体现都是以对象的形式,所以为了方便对多个对象的操作,就对对象进行存储,集合就是存储对象最常用的一种方式。
数组和 集合的区别:
1,数组虽然也可以存储对象,是一种容器,但是其长度是固定的,集合的长度是可变的。
2,数组中可以存储基本数据类型,但集合只能存储对象。
集合类的特点:集合只用于存储对象,长度可变,可以存储不同类型的对象。
Collection接口:是结合框架的根接口。
Collection接口的方法:
package 博客6_集合框架一;import java.util.*;public class Collection中的共性方法 {/** * @param args */public static void main(String[] args) {method_get();}public static void method_get()//取出元素{ArrayList al = new ArrayList();//1,添加元素。al.add("java01");al.add("java02");al.add("java03");al.add("java04");Iterator it = al.iterator();//迭代器接口,获取迭代器while(it.hasNext())//有元素的时候返回真{sop(it.next());//用迭代器取出元素}}public static void base_method2(){ArrayList al1 = new ArrayList();//1,添加元素。al1.add("java01");al1.add("java02");al1.add("java03");al1.add("java04");ArrayList al2 = new ArrayList();//1,添加元素。al2.add("java01");al2.add("java02");al2.add("java05");al2.add("java06");//取交集,al1中只会保留与al2中相同的元素//al1.retainAll(al2);al1.removeAll(al2);sop("al1:"+al1);sop("al2:"+al2);}public static void base_method(){// TODO Auto-generated method stub//创建一个集合容器,使用Collection接口的子类ArrayListArrayList al = new ArrayList();//1,添加元素。al.add("java01");al.add("java02");al.add("java03");al.add("java04");//打印集合sop(al);//删除元素。al.remove("java02");sop("改变后的集合:。。。"+al);//清空集合//al.clear();//判断元素。sop(al.contains("java03"));sop(al.isEmpty());//2,获取个数,集合长度//sop("size:"+al.size());}public static void sop(Object obj){System.out.println(obj);}}迭代器:集合用于取出元素的方式。
注意:集合中存储的都是对象的引用(地址)。
二、List集合
Collection
|--List:元素是有序的,可以重复,因为该集合体系有索引。
|--Set:元素是无序的,且不可以重复。
List集合:凡是可以操作角标的方法都是该体系的特有方法。
List集合的特有方法:
1,增
add(index,element);
addAll(index,Collection);
2,删
remove(index);
3,改
set(index,element);
4,查
get(index);
subList(from,to);
listIterator();
package 博客6_集合框架一;import java.util.*;public class List集合中的共性方法 {/** * @param args */public static void main(String[] args) {// TODO Auto-generated method stubmethod();}public static void method(){ArrayList al = new ArrayList();al.add("java01");al.add("java02");al.add("java03");al.add("java04");sop("原集合是:"+al);//在指定位置添加元素//al.add(1,"java09");//删除指定位置的元素//al.remove(1);//修改元素//al.set(2, "java08");//通过角标获取元素//sop("get(1):"+al.get(1));//获取所有元素for(int x = 0 ;x <al.size();x++){System.out.println("al("+x+")="+al.get(x));}sop(al);//通过indexOf获取对象的位置sop("index="+al.indexOf("java02"));List sub =al.subList(1,3);sop(sub);}public static void sop(Object obj){System.out.println(obj);}}ListIterator:列表迭代器。是List集合特有的迭代器,是Iterator的子接口。
在迭代时,不可以通过集合对象的共性方法来操作集合中的元素,因为会发生ConcurrentModificationException异常。
ConcurrentModificationException:并发修改异常。
所以,在迭代时,还能用迭代器的方法来操作元素。如果想对元素进行添加,修改等操作,就需要使用期子接口ListIterator。该接口只能通过List集合的ListIterator获取。
package 博客6_集合框架一;import java.util.*;public class ListIteratorDemo {/** * @param args */public static void main(String[] args) {// TODO Auto-generated method stubArrayList al = new ArrayList();al.add("java01");al.add("java02");al.add("java03");al.add("java04");ListIterator li = al.listIterator();//创建列表迭代器while(li.hasNext()){Object obj = li.next();//多态,父类引用指向子类对象if(obj.equals("java02"))//li.add("java05");//添加元素li.set("java006");//更改元素}sop(al);}public static void sop(Object obj){System.out.println(obj);}}三、List常用子类对象
List
|--ArrayList:底层的数据结构是数组结构。特点是查询速度很快,但是增删稍慢,线程不同步。
|--LinkedList:底层使用的是链表数据结构,增删速度很快,但是查询速度稍慢
|--Vector:底层是数组数据结构,但是线程是同步的,已经被ArrayList取代。
Vector集合的特有取出方式是枚举。他和迭代是一样的,但是由于其名称和方法过长,所以被迭代器所取代。
package 博客6_集合框架一;import java.util.Enumeration;import java.util.Vector;public class EnumerationDemo {/** * @param args */public static void main(String[] args) {// TODO Auto-generated method stubVector 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());}}}四、Set集合及其子类
Set集合:元素是无序的(存入和取出的顺序不一定一致),且元素不可重复。
Set:方法和Collection一样。
|--HashSet:底层数据结构是哈希表。通过元素的两个方法hashcode和equals来保证元素的唯一性,如果hashcod值相同,才会判断equals是否为真,如果不同,则不会调用equals方法。
|--TreeSet:可以对Set集合中的元素进行排序,底层数据结构是二叉树,保证元素唯一性的依据是通过CompareTo方法看返回值是否为0.
package 博客6_集合框架一;import java.util.HashSet;import java.util.Iterator;public class HashSetDemo {/** * @param args */public static void main(String[] args) {// TODO Auto-generated method stubHashSet hs = new HashSet();hs.add("java01");hs.add("java02");hs.add("java03");hs.add("java04");Iterator it = hs.iterator();while(it.hasNext()){System.out.println(it.next());}}}HashSet练习:
package 博客6_集合框架一;import java.util.HashSet;import java.util.Iterator;public class HashSetText {/** * 需求:用hashSet存储自定义对象,当姓名和年龄都相同时,视为一个人,不存。 */public static void main(String[] args) {// TODO Auto-generated method stubHashSet hs = new HashSet();hs.add(new Person("zhangsan",13));hs.add(new Person("liss",15));hs.add(new Person("wangwu",23));hs.add(new Person("zhangsan",13));Iterator it = hs.iterator();while(it.hasNext()){Person p = (Person)it.next();sop(p.getName()+"......"+p.getAge());}}public static void sop(Object obj){System.out.println(obj);}}class Person{private String name;private int age;Person(String name,int age){this.name=name;this.age=age;}public String getName(){return name;}public int getAge(){return age;}public boolean equals(Object obj)//复写object类中的equals方法{if(!(obj instanceof Person))return false;Person p = (Person) obj;return this.name.equals(p.name)&&this.age==p.age;}public int hashCode()//复写hashCode方法{return name.hashCode()+age*78;//保证哈希值唯一}}TreeSet排序的两种方式:
1,让元素自身具备比较性,元素需要实现Comparable接口,也称为元素的自然顺序,或者默认顺序。
2,当元素自身不具备比较性时,或者具备的比较性不是所需要的,就需要让容器自身具备比较性。定义比较器,将比较器作为参数传递给TreeSet集合的构造函数。
当两种排序都存在时,以比较器为主。
比较器建立方法:定义一个类,实现comparator接口,覆盖compare方法即可。
Comparable接口:强行对实现它的每个类的对象进行整体排序。
- 黑马程序员--集合框架笔记(一)
- 黑马程序员_集合框架(一)
- 黑马程序员 集合框架(一)
- 黑马程序员--集合框架(一)
- 黑马程序员:java集合框架(一)
- 黑马程序员------集合框架(一)
- 黑马程序员_JAVA_集合框架(一)
- 黑马程序员----集合框架(一)
- 黑马程序员-集合框架(一)
- 黑马程序员--Java集合框架(一)
- 黑马程序员_集合框架(一)
- 黑马程序员_集合框架(一)
- 黑马程序员---集合框架(一)
- 黑马程序员--集合框架(一)
- 黑马程序员 集合框架一
- 黑马程序员——集合框架(一)
- 【黑马程序员】集合框架(一) 第十五天
- 黑马程序员_全面接触Java集合框架(一)
- 程明明-关于文献阅读和寻找新的科研题目
- hdu 1269 迷宫城堡
- 临界区,互斥量,信号量,事件的区别
- java基础之对properties配置文件的读写操作
- 黑马程序员——OC-Setter/Getter函数及@proterty和@synthesize
- 黑马程序员---集合框架(一)
- 数据结构例程——图的邻接矩阵存储结构及算法
- Java 8中的增强的Arrays
- 《剑指offer》——斐波那契数列
- 从系统角度看分布式系统的挑战
- 简单的二叉树创建及其基本的运算(C语言)
- OpenCV中IplImage图像格式与BYTE图像数据的转换
- Android录音播放工具类,仿微信语音聊天。
- mvc intranet应用程序访问出错