Java基础知识总结(60)

(3)LinkedHashSet

    HashSet有一个子类LinkedHashSet,LinkedHashSet集合同HashSet一样,也是根据元素的hashCode值来确定元素的存储位置,并且通过链表维护元素的顺序,换句话说,遍历LinkedHashSet时,LinkedHashSet将会按照元素的添加顺序来访问集合里的元素。

    如果在某些场景下要使用set容器保存元素,并且需要维护set中的存放元素的顺序,那么就可以使用LinkedHashSet

public class Test3 {

    public static void main(String[] args) {

        LinkedHashSet<String> set = new LinkedHashSet<>();

        set.add("贞观之治");

        set.add("开元盛世");

        set.add("文景之治");

        //添加进容器的元素和取出的元素顺序是一致的。

        set.forEach(e-> System.out.println(e));

    }

}

(4)TreeMap

   

    TreeMap 就是一个红黑树数据结构,每个 key-value 对即作为红黑树的一个节点。TreeMap 存储 key-value 对(节点)时,需要根据 key 对节点进行排序。

public class TreeMapDemo {

    public static void main(String[] args) {

        TreeMap<Integer,String> map = new TreeMap<Integer,String>();

        map.put(1,"苏轼");

        map.put(2,"李白");

        map.put(3,"杜甫");

        map.put(4,"岑参");

        //返回该 Map 中最小 key 所对应的 key-value 对,如果该Map为空,则返回 null。

        System.out.println(map.firstEntry());

        //返回该 Map 中的最小 key值,如果该 Map为空,则返回 null。> Map.Entry lastEntry()∶ 返回该 Map 中最大 key 所对应的 key-value 对,如果该 Map为空或不存在这样的 key-value 对,则都返回 null。

        System.out.println(map.firstKey());

        //返回该 Map 中的最大 key 值,如果该 Map 为空或不存在这样的 key,则都返回nulI。

        System.out.println(map.lastKey());

        //返回该 Map 中位于key 后一位的 key 值(即大于指定 key 的最小key 值)。如果该 Map 为空或不存在这样的 key-value 对,则都返回 nul 。

        System.out.println(map.higherKey(2));

        //返回该 Map 中位于key 后一位的 key-value 对(即大于指定key 的最小 key 所对应的 key-value 对)。如果该 Map 为空,则返回 null。

        System.out.println(map.higherEntry(2));

        //返回该Map 中位于key前一位的 key 值(即小于指定 key 的最大key 值)。如果该 Map 为空或不存在这样的 key,则都返回 null。

        System.out.println(map.lowerKey(3));

        //返回该 Map 中位于key 前一位的 key-value 对(即小于指定key 的最大 key 所对应的 key-value 对)。如果该 Map 为空或不存在这样的 key-value 对,则都返回 null。

        System.out.println(map.lowerEntry(3));

    }

}

   

(5)TreeSet

   

    TreeSet 是 SortedSet 接口的实现类,TreeSet 可以确保集合元素处干排序状态。

/**

 * //凡是要在TreeSet中添加的元素必须要继承Comparable接口,并重写compareTo方法

 * //a.compareTo(b) >0  a>b

 * //a.compareTo(b) ==0 a=b

 * //a.compareTo(c) <0  a<b

 * //TreeSet中判断两个对象是否相等依赖于Comparable接口的compareTo方法,不依赖于equals方法。

   */

   public class TreeSetDemo {

   public static void main(String[] args) {

       TreeSet<Student> treeSet = new TreeSet<>();

       Student s1 = new Student("小明",18);

       Student s2 = new Student("小红",18);

       //添加成功

       treeSet.add(s1);

       //添加失败,因为通过compareTo方法判断出两个对象相等

       treeSet.add(s2);

       treeSet.forEach(student -> System.out.println(student));

   }

   }

常用API

public class TreeSetDemo1 {

    public static void main(String[] args) {

        TreeSet<Integer> treeSet = new TreeSet<Integer>();

        treeSet.add(11);

        treeSet.add(12);

        treeSet.add(12);

        treeSet.add(13);

        treeSet.add(31);

        System.out.println(treeSet.comparator());

        //返回集合中的第一个元素。

        System.out.println(treeSet.first());

        //返回集合中的最后一个元素。

        System.out.println(treeSet.last());

        //返回集合中位于指定元素之前的元素

        System.out.println(treeSet.lower(12));

        //返回集合中位于指定元素之后的元素

        System.out.println(treeSet.higher(12));

        //返回此Set 的子集合,范围从fromElement(包含)到 toElement (不包含)。

        System.out.println(treeSet.subSet(11,13));

        //返回此 Set 的子集,由小于 toElement 的元素组成

        System.out.println(treeSet.headSet(32));

        //返回此 Set 的子集,由大于或等于 fromElement 的元素组成。

        System.out.println(treeSet.tailSet(11));

    }

}

  • 18
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
一、Java基础语法 1.变量和常量 变量用于存储数据。Java中的变量有三种类型:局部变量、成员变量和静态变量。 常量是指在程序运行时不会被修改的值,在Java中用final关键字标识。常量分为静态常量和实例常量。 2.数据类型 Java中的数据类型分为基本数据类型和引用数据类型。基本数据类型有byte、short、int、long、float、double、char和boolean。 引用数据类型包括类、接口、数组和枚举。 3.运算符 Java中的运算符包括算术运算符、关系运算符、逻辑运算符、位运算符、三目运算符等。 4.流程控制 Java中的流程控制有if-else语句、switch-case语句、for循环、while循环、do-while循环、break语句、continue语句等。 二、面向对象编程 1.类和对象 类是对象的实体,包含属性和方法。对象是类的实例,具有独立的状态和行为。 2.继承和多态 继承是指一个类可以继承另一个类的属性和方法。 多态是指同一种操作作用于不同的对象,可以有不同的实现方式,实现方式由实际的对象类型决定。 3.封装和抽象 封装是指将类的属性和方法进行隐藏,只对外暴露必要的接口。通过封装可以保证类的安全性和灵活性。 抽象是指将类的共性进行概括,并去除与具体实现无关的内容。通过抽象可以提高代码的复用性和可维护性。 三、异常处理 在Java中,异常是指程序执行时发生的错误或异常情况。Java中的异常处理机制可以有效地避免程序运行中的错误导致程序崩溃。 Java中异常处理机制可以通过try-catch语句捕获异常,并通过throw和throws语句抛出和传递异常。在异常处理中可以利用finally语句完成清理工作。 四、集合框架 Java中的集合框架是对容器类的统称,包括List、Set和Map等容器类。 List是一个有序的容器,允许重复的元素。Set是一个无序的容器,不允许重复的元素。Map是一种键值对的映射容器。 五、IO操作 Java中的IO操作包括字节流和字符流。字节流操作的是二进制数据,字符流操作的是文本数据。 Java中的IO操作可以通过输入流和输出流来实现。输入流用于读取数据,输出流用于写入数据。 六、线程 线程是指程序中的一个执行流程,一个程序可以同时运行多个线程执行不同的任务。 在Java中,可以通过继承Thread类或实现Runnable接口来创建线程。 Java中的线程可以通过synchronized关键字来实现同步,防止线程间数据的冲突。 七、JDBC数据库操作 JDBC是Java数据库连接的一种标准,可以用于连接关系型数据库的操作。使用JDBC需要进行数据库驱动的加载,然后进行数据库连接,最后进行数据库的增删改查等操作。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

好教员好

您的鼓励是我前进动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值