java中集合的体系

一、集合的体系分类

  分为单列集合,双列集合。和数组相比,大小可变更加灵活。
  List集合有序可重复有索引,Vector线程安全。
  Set集合无序不重复无索引,但带Linked则有序。
  Map是无序不重复无索引的。
  带Tree则是排序集合。也就是说,这种集合里面的元素都是按照一定的规则的顺序存放的,这个规则也可以由我们定。
在这里插入图片描述

二、集合常用的方法

Collection

  以ArrayList为例,主要有add,remove,contains,clear,isEmpty,size,toArray等。

List<String> list = new ArrayList<>();
//添加元素
list.add("张三");
list.add("李四");
list.add("王五");
//删除元素(根据索引操作是List特有的)
list.add(2,"钱七");//按索引添加
list.set(1,"赵六");//按索引修改
list.get(2);//按索引取出元素
list.remove(1);//按索引删除元素
list.remove("张三");
//判断是否包含某个元素,返回布尔类型的值
list.contains("张三");
//清空集合
list.clear();
//判断是否为空
list.isEpmty();
//返回集合元素个数
list.size();
//把集合元素存到数组中
list.toArray();
Map

  以HashMap为例,常用方法和Collection集合思路上大同小异。集合增加元素为put。putAll合并集合。get(key)根据键找值。着重说一下keySet,entrySet。

Map<String,Integer> maps = new HashMap<>();
maps.put("岳麓山",10);
maps.put("橘子洲头",15);
maps.put("桃花岭",8);
// 获取全部键的集合
Set<String> keys = maps.keySet();
// 获取全部值的集合
Collection<Integer> values = maps.values();
//遍历map集合
Set<Map.Entry<String, Integer>> entries = maps.entrySet();
	for(Map.Entry<String,Integer> entry :entries){
    	String key = entry.getKey();
        int value = entry.getValue();
        System.out.println(key + "->" + value);
        }

三、Collectinos

  是操作集合的工具类,有很多方法。例如Collections.addAll(list,…)批量添加元素,Collections.sort(list)给集合排序,Collections.shuffle(list)打乱集合元素的顺序。

List<String> list = new ArrarList<>();
Conllections.addAll(list,"周依","邹迩","舟莎","宙斯");
Conllections.shuffle(list);
Conllections.sort(list);//按默认规则排序

//可以自定义规则
Collections.sort(list, new Comparator<E>() {
    @Override
    public int compare(E o1, E o2) {
        return Double.compare(o1.getXXX(), o2.getXXX());
    }
});

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值