Java中的集合类

集合类

集合类存放于java.util包中。
集合类存放的都是对象的引用,而非对象本身,出于表达上的便利,我们称集合中的对象就是指集合中对象的引用(reference)。

集合类的类型

集合类型主要有3种:set(集)、list(列表)和map(映射)。
集合接口分为:Collection和Map
list和set继承了Collection接口
而Map没有子接口

list接口

list接口的特点:有序 可重复

实现list接口的类
  • ArrayList 内部使用数组实现

  • LinkedArrayList 内部使用链表实现

为了便于理解上述接口与类的关系,给出一个继承结构
Collection<--List<--ArrayList
Collection<--List<--LinkedList

set接口

set接口特点:无序 不可重复

map接口

map接口就是指映射关系 Key-Value 键值对
map接口的特点:键必须不同 值可以相同

集合与普通数组相比的优势

数组:存储多个类似对象
普通数组弊端:长度不可变

集合的优势: 实际开发中可以随便改变长度的数组->集合

接口Collection含有的方法的方法

添加元素
Collection t1=new ArrayList();
       
        t1.add("Jack");
删除元素
 Collection t1=new ArrayList();
t1.remove("Jack");
获取元素的个数
Collection t1=new ArrayList();
t1.size()
判断是否包含某个元素
Collection t1=new ArrayList();
 t1.add("Merry");
if (t1.contains("Merry"))
        {
            System.out.println("有Merry");
        }
        else
        {
            System.out.println("没有Merry");
        }
判断集合是否为空
Collection t1=new ArrayList();
if (t1.isEmpty())
        {
            System.out.println("为空");
        }
判断两个集合是否为相同
Collection t1=new ArrayList();
Collection t2=new ArrayList();
        t1.add("Merry");
        t2.add("Jack");
        t2.add("Merry");
        if (t1.equals(t2))//这时的equals是比较内容
        {
            System.out.println("不相同");
        }
清空元素
    Collection t1=new ArrayList();
     t1.add("Merry");
     t1.clear();

Arraylist//LinkedArraylist 含有的方法

添加和插入方法
        ArrayList score=new ArrayList<>();
        score.add(2);//在末尾加入
        score.add(0,2);//在指定位置前插入,在第0号位置前插入值为6的元素
修改元素内容
        ArrayList score=new ArrayList<>();
        score.set(0,6);//把第0号位置的值改为6
        System.out.println(score);
删除
        ArrayList score=new ArrayList<>();
        score.remove(0);//删除第0号位置的值
        score.remove((Integer) 2);//删除内容为2的元素
清空
ArrayList score=new ArrayList<>();
 score.clear();
把其他集合里的元素添加到本集合中
 ArrayList score=new ArrayList<>();
ArrayList s1=new ArrayList<>();
        s1.add(1);
        s1.add(2);
        s1.add(9);
        score.addAll(s1);//把s1集合的元素添加到score集合中
求两个集合的交集
 ArrayList score=new ArrayList<>();
ArrayList s1=new ArrayList<>();
        s1.add(1);
        s1.add(2);
        s1.add(9);
score.retainAll(s1);//求s1和score两个集合的交集并赋给集合score
访问某个对象在集合里的索引,如果该对象不存在返回-1
ArrayList s1=new ArrayList<>();
        s1.add(1);//索引0
        s1.add(2);//索引1
        s1.add(9);//索引2
int i=s1.indexOf(2)//返回元素内容为2的索引,所以i的值为1

关于Arraylist//LinkedArraylist 的注意事项

Arraylist//LinkedArraylist 集合里面,只能存放对象 不能直接存放基本类型数据
要存放基本数据类型就要存放其对应的包装类

     byte int long float double boolean
     基本数据类型和其对应的包装类
     Byte Integer Long Float Double Boolean

如何遍历集合

1.使用 Iterator(迭代器)
Iterator的方法

hasNext 判断是否还有下一个元素
next 获取下一个元素
remove 删除当前遍历过后的元素

Collection t2=new ArrayList();
       t2.add("Jack");
        t2.add("Merry");
  Iterator iterator=t2.iterator();//这是要对t2进行遍历

        while (iterator.hasNext())
        {
            System.out.println(iterator.next());
        }

      
2.for-each循环
Collection t2=new ArrayList();
       t2.add("Jack");
        t2.add("Merry");
for (String obj:t2)
        {
            System.out.println(obj);
        }
3.普通for循环
Collection t2=new ArrayList();
       t2.add("Jack");
        t2.add("Merry");
for (int i=0;i) t2).get(i));
        }

你可能感兴趣的:(Java中的集合类)