java集合框架---List/Set

|–List:元素是有序的,元素可以重复。因为该集合体系有索引。

|–ArrayList:底层的数据结构使用的是数组结构。特点:查询速度很快,但是增删较慢。线程不同步。

|–linkedList:底层使用的是链表数据结构。特点:增删速度很快,查询稍慢。

|–Vector:底层是数组数据结构。特点:线程同步,被ArrayList替代。

|–Set:元素是无序的,元素不可重复。

|–HashSet: 底层数据结构是哈希表。线程是非同步的。

保证元素唯一性原理:判断hashcode值是否相等,再判断equals方法。

|–TreeSet: 可以对Set集合中的元素进行排序

底层结构是二叉树

保证元素唯一性的依据:compareTo方法return 0

排序方法1:实现Comparable接口,并重写compareTo方法

排序方法2:实现comparator接口,并重写compare方法

package pack;

import java.util.*;

public class Demo {

    public static void sys(Object obj) {

        System.out.println(obj);
    }

    public static void main(String[] args) {

        method8();

    }
    public static void method1() {

        ArrayList al = new ArrayList();   //创建集合,collection的子类,ArrayList
        al.add("java1");
        al.add("java2");
        al.add(1,"java9");  //增
        al.remove(1);    //删
        al.set(1, "hello");  //改
        al.get(1);  //查
        al.add(23);
        //al.remove("java1");
        //al.clear();
        sys(al.indexOf("hello"));
        sys(al.isEmpty());
        sys(al.contains("java"));
        sys(al);     //输出列表
        sys("size="+al.size());

        for(int i = 0;i<al.size();i++) {
            al.get(i);
        }
        /*
        Iterator it=al.iterator();  //获取迭代器,取出元素
        while(it.hasNext()) {
            sys(it.next()); */
        for(Iterator it = al.iterator();it.hasNext();) {
            sys(it.next());
        }   

    }

    public static void method2() {

        ArrayList al1 = new ArrayList();
        al1.add("java1");
        al1.add("java2");
        al1.add("java3");
        ArrayList al2 = new ArrayList();
        al2.add("java2");
        al2.add("java3");
        al2.add("java4");

        al1.retainAll(al2);  //取交集
        al1.removeAll(al2);  //去除交集

        /*for(Iterator it = al2.iterator();it.hasNext();) {
            if(it.next().equals("java3"))
                it.remove();    //此迭代器只能删除,其它做不了,会出现并发修改异常。
                                //所以出现了ListIterator
        }*/

        /*for(ListIterator li = al2.listIterator();li.hasNext();) {
            if(li.next().equals("java2"))
                al2.add("java");
        }*/
        sys(al2);
    }
    public static void method3() {

        Vector v = new Vector();
        v.add("java1");
        v.add("java2");
        v.add("java3");
        //sys(v);
        for(Enumeration en = v.elements();en.hasMoreElements();) //枚举是Vector的特有取出方式
            sys(en.nextElement());
    }

    public static void method4() {

        LinkedList link = new LinkedList();
        link.addFirst("java1");
        link.addLast("java2");
        link.addFirst("java3");
        sys(link.getFirst());  //取
        sys(link.removeFirst()); //取、删
        /*
        while(!link.isEmpty()) {
            sys(link.removeFirst());
        }*/
    }

    public static void method5() {

        HashSet hs = new HashSet();
        hs.add("java1");
        sys(hs.add("java1"));  //false,set里无重复,添加失败
        hs.add("java2");
        hs.add("java3");
        hs.add("java4");
        for(Iterator it = hs.iterator();it.hasNext();) {   //set只能迭代输出
            sys(it.next());
        }
    }

    public static void method6() {

        HashSet hs = new HashSet();
        hs.add(new Person("aa",1));
        hs.add(new Person("bb",6));
        hs.add(new Person("cc",3));
        hs.add(new Person("dd",4));
        for(Iterator it = hs.iterator();it.hasNext();) {
            sys(((Person)it.next()).getName());
            sys(((Person)it.next()).getAge());
        }

    }

    public static void method7() {      //TreeSet特点:比较性
        TreeSet ts = new TreeSet();
        ts.add(new Person("aa",1));
        ts.add(new Person("bb",6));
        ts.add(new Person("cc",3));
        ts.add(new Person("dd",4));
        /*for(Iterator it = ts.iterator();it.hasNext();) {  //4个元素排序了
            sys(((Person)it.next()).getName()+((Person)it.next()).getAge());
        }*/

        Iterator it = ts.iterator();
        while(it.hasNext()) {
            Person p = (Person)(it.next());
            sys(p.getName()+"----"+p.getAge());
        }
    }

    public static void method8() {
        TreeSet ts = new TreeSet(new Mycompare());  //往构造函数传入比较器对象
        ts.add(new Person("aa",1));
        ts.add(new Person("bb",6));
        ts.add(new Person("cc",3));
        ts.add(new Person("dd",4));
        Iterator it = ts.iterator();
        while(it.hasNext()) {
            Person p = (Person)(it.next());
            sys(p.getName()+"----"+p.getAge());
        }
    }
}

/*该接口强制让人对象具备比较性。因为TreeSet输出要排序的,而人对象不具备比较性,输出出错,
  因此要实现Comparable,并重写compareTo方法*/
class Person implements Comparable {    //实现接口是为了method7()

    private  String name;
    private  int age;
    Person(String name,int age) {
        this.name = name;
        this.age = age;
    }

    public int compareTo(Object obj) {   //重写compareTo方法,指定以年龄为排序方式

        if(!(obj instanceof Person)) {
            throw new RuntimeException("not Person object");
        }
        Person p = (Person)obj;
        if(this.age>p.age)
            return 1;
        /*if(this.age==p.age)   //这是不对的,如果两个人年龄相同救返回0,被认为是同一对象,
         *                        按照Set的规则将不保存后面这个元素
            return 0;*/
        if(this.age==p.age) {
            return this.name.compareTo(p.name); //年龄相同时按照姓名排序
        }
        else
            return -1;
    }

    public String getName() {
        return name;
    }

    public int getAge() {
        return age;
    }
}

class Mycompare implements Comparator {    //实现个比较器,实现接口是为了method8()
    public int compare(Object o1,Object o2) {    //重写compare方法
        Person p1 = (Person)o1;
        Person p2 = (Person)o2;
        int a = p1.getName().compareTo(p2.getName());  //按姓名比较
        if(a==0) {
            if(p1.getAge()>p2.getAge())
                return 1;
            if(p1.getAge()==p2.getAge())
                return 0;
            else
                return -1;
        }
        return a;

    }
}
时间: 2024-08-26 02:41:08

java集合框架---List/Set的相关文章

Java—集合框架List

集合的概念 现实生活中:很多的事物凑在一起 数学中的集合:具有共同属性的事物的总和 Java中的集合类:是一种工具类,就像是容器,存储任意数量的具有共同属性的对象 集合的作用 在类的内部,对数据进行组织(针对作用与意义一样的属性,将他们放到一个集合中) 简单而快速的搜索大数量的条目 有的集合接口,提供了一系列排列有序的元素,并且可以在序列中快速的插入或删除有关元素 有的集合接口,提供了映射关系,可以通过关键字(key)去快速查找到对应的唯一对象,而这个关键字可以是任意类型 与数组相比 数组的长度

《深入理解Java集合框架》系列文章

Introduction 关于C++标准模板库(Standard Template Library, STL)的书籍和资料有很多,关于Java集合框架(Java Collections Framework, JCF)的资料却很少,甚至很难找到一本专门介绍它的书籍,这给Java学习者们带来不小的麻烦.我深深的不解其中的原因.虽然JCF设计参考了STL,但其定位不是Java版的STL,而是要实现一个精简紧凑的容器框架,对STL的介绍自然不能替代对JCF的介绍. 本系列文章主要从数据结构和算法层面分析

JAVA集合框架

收藏 查看我的收藏 146有用+1 56 编辑 Java,是由Sun Microsystems公司于1995年5月推出的Java程序设计语言和Java平台的总称.用Java实现的HotJava浏览器(支持Java applet)显示了Java的魅力:跨平台.动态的Web.Internet计算.从此,Java被广泛接受并推动了Web的迅速发展,常用的浏览器现在均支持Java applet.集合框架是为表示和操作集合而规定的一种统一的标准的体系结构.任何集合框架都包含三大块内容:对外的接口.接口的实

我所理解Java集合框架的部分的使用(Collection和Map)

所谓集合,就是和数组类似--一组数据.java中提供了一些处理集合数据的类和接口,以供我们使用. 由于数组的长度固定,处理不定数量的数据比较麻烦,于是就有了集合. 以下是java集合框架(短虚线表示接口,长虚线表示抽象类,实线表示类,箭头表示实现接口或者继承)(在网络上找的图,不知道原作者,侵权请联系我删除)(总之,关系很复杂,所以不用记得这个图,只是用来吓吓人而已的). 下面贴上个人理解之精简版之Collection(集)和Map(地图?暂且这么理解吧),话说思维导图蛮好用,以下是两幅思维导图

【Java集合源码剖析】Java集合框架

Java集合工具包位于package java.util下.包含了一些常用的数据结构,如数组.链表(单/双向).树.栈.队列.哈希表等. Java集合框架大致可分为五部分:List列表.Set集合.Map映射.迭代器(Iterator.Enumeration).工具类(Arrays.Collections). Java集合类的整体框架如下: 如图,Java集合类大致分为两大类:Collection和Map. Collection主要包括两部分:List和Set. List接口通常表示一个列表(数

Java集合框架总结(3)——TreeSet类的排序问题

Java集合框架总结(3)--TreeSet类的排序问题 TreeSet支持两种排序方法:自然排序和定制排序.TreeSet默认采用自然排序. 1.自然排序 TreeSet会调用集合元素的compareTo(Object obj)方法来比较元素之间大小关系,然后将集合元素按升序排列,这种方式就是自然排序.(比较的前提:两个对象的类型相同). java提供了一个Comparable接口,该接口里定义了一个compareTo(Object obj)方法,该方法返回一个整数值,实现该接口的类必须实现该

2016.3.9-3.10(java集合框架)

3.9 集合框架有什么作用? 集合框架其主要功能是用来将存储的数据以某种结构组织,并以特定的方式来访问这些数据. Java集合框架中有哪些存储方式? Java集合框架中的对象容器,按照对象在其中的存储方式,分为Set.List.和Map三种类型. Set类型对象没有顺序,且不能重复: List类型对象容器中的对象按照索引顺序排序,而且可以有重复的对象: Map类型对象容器中的元素包含一对“键对象-值对象”映射,其中键对象不能重复,值对象可以重复. 以上三种存储方式对应Java集合框架中Set.L

java集合框架22

思想:在面向对象的思想里,一种数据结构被认为是一种容器.在本质上来讲是一个类,提供方法支持查找,插入和删除等等操作. Java集合框架支持以下俩种类型的容器: 存储一个元素集合,简称为集合Collection 存储键值对,称为图Map 集合collection 三种主要类型 : 规则集(set) , 线型表(List) , 队列(Queue) set: 存储一组不重复的数据 List: 存储由元素构成的有序集合 Queue: 存储先进先出方式处理的对象 细说Collection接口: 它是处理对

Java集合框架的知识总结

说明:面试准备,写的挺不错的. 转载地址: http://www.cnblogs.com/zhxxcq/archive/2012/03/11/2389611.html 1.综述 所有集合类都位于java.util包下.集合中只能保存对象(保存对象的引用变量).(数组既可以保存基本类型的数据也可以保存对象). 当我们把一个对象放入集合中后,系统会把所有集合元素都当成Object类的实例进行处理.从JDK1.5以后,这种状态得到了改进:可以使用泛型来限制集合里元素的类型,并让集合记住所有集合元素的类

Java集合框架之泛型

广州疯狂软件教育Java培训,iOS培训分享 泛型:1.5版本以后出现的新特性.用于解决安全问题,是一个安全机制. 好处: 1.将运行时期出现问题ClassCaseException,转移到了编译时期. 2.方便与程序员解决问题.让运行时事情减少,安全. 3.避免了强制类型转换 泛型格式:通过<>来定义要操作的引用数据类型 什么时候写泛型: 在集合框架中和常见 只要见到<>就要定义泛型 import java.util.Comparator; import java.util.It