java017

1,HashSet

底层结构:哈希表(数组+链表+红黑树)->是由HashMap维护

优点:查询,增删效率较高

缺点:无序

应用场景:实现不存储相同数据.查询,增删效率较高的时候建议使用HashSet

新增功能:无新增功能

去重:需要在存储数据的类型中重写hashcode与equals方法实现数据的去重

2,TreeSet

存储自定义引用数据类型的数据

去重问题:存储自定义引用数据类型对象的时候,去重与排序问题都按照比较规则

比较器:

内部比较类|自然排序;定义在一个类型的内部的比较方式

优点:默认比较方式,定义在类的内部

缺点:固定,硬编码,不够灵活

外部比较器:

定义一个类型(要比较的对象数据的类型)的外部的比较方式

实现 java.util.Comparator接口,重写compare(T t1,T t2)定义比较

注意:如果使用的时候指定了定值排序使用定值排序,没有指定使用自然排序

2.2,Arrays.sort默认升序

默认比较规则

Arrays.sort(数组名)

使用两个参数指定的外部比较规则

 Arrays.sort(arr, (t1,t2)->t1.getAge()-t2.getAge());

3,Map<k,v>

集合中的泛指元素是k->key和V->value值组成

k:可以为任意引用数据类型数据->Set无序不可重复

v:可以为任意引用数据类型数据->Collection可重复无序

一个Key只能对应一个value->映射关系

可以根据key操作value

Map的无序与去重由key决定

Map的遍历方式:

1.keySet

Set set=hasp.keySet();
        for(Object S:set){
            System.out.println(S+"--"+hasp.get(S));
        }

2.Value值

Collection<String> col = map.values();
        for(String s:col){
            System.out.println(s);
        }

3.entrySet

Set<Map.Entry<Integer,String>> set = map.entrySet();
        Iterator<Map.Entry<Integer,String>> it = set.iterator();
        for(;it.hasNext();){
            Map.Entry entry = it.next();
            System.out.println(entry.getKey()+"-->"+entry.getValue());
        }

4,HashMap

底层结构:哈希表(数组+链表+红黑树)

特点:查询,增删效率较高

扩容问题:初始量16,newCap=oldCap<<1数组每次扩容原容量的两倍

DEFAULT_INITIAL_CAPACITY 初始容量 16
DEFAULT_LOAD_FACTOR : 默认加载因子 0.75
threshold : 扩容临界值 DEFAULT_LOAD_FACTOR * DEFAULT_INITIAL_CAPACITY

遍历方式与Map接口相同

4.2TreeMap

TreeSet底层是由TreeMap维护的

底层:红黑树

特点:自动做升序排序

5,Properties

存储字符串类型的键值对,Properties可以保存到流中或从流中加载

优点:可以通过Properties实现软编码,从满足Properties特点的配置文件中读取数据,便于后期维护修改

使用步骤:

1.定义一个配置文件

2.创建Properties类型的对象,调用load从流中加载(输入流的数据源就是配置文件)
3.从配置文件中读取数据,加载使用

例如:

Properties pro = new Properties();

        //void load(InputStream inStream) 从输入字节流中读取属性列表(键和元素对)。
        pro.load(Thread.currentThread().getContextClassLoader().getResourceAsStream("db.properties"));
        System.out.println(pro.getProperty("username"));
        System.out.println(pro.getProperty("password"));

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值