②sort方法:排序方法 若是数字,按照从小到大的顺序排列; 若是字符串,则按照字符串首字母对应ASCII码表从小到大。 ③shuffle方法:乱序方法 将集合中的所有元素打乱。...三、比较器 Java里面有两个比较器:Comparator和Comparable。...②比较器Comparator: 使用匿名内部类,因为Comparator是一个接口,没法实例化创建对象,需要子类创建对象,因为子类对象只需要使用一次,所以可是使用匿名内部类。...①将我们创建的类实现Comparable比较器。 这样做了,就可以直接使用Collections的sort方法,不然会报错。...若是我们自己创建的类需要排序,就得自己实现Comparable比较器 ②重写Comparable的compareTo方法。
java中Set集合是一个不包含重复元素的Collection,首先我们先看看遍历方法 package com.sort; import java.util.HashSet; import java.util.Iterator...String类型,假如我们放入一个自己定义的类实例的时候,比如Person类实例,这时候我们要自己重新hashcode和equal方法,用自己的关键字段来重写,因为当使用HashSet时,hashCode...()方法就会得到调用,判断已经存储在集合中的对象的hash code值是否与增加的对象的hash code值一致;如果不一致,直接加进去;如果一致,再进行equals方法的比较,equals方法如果返回...下面分析一下Set集合的另外一个重要实现类TreeSet, TreeSet使用元素的自然顺序对元素进行排序,或者根据创建 set 时提供的 Comparator 进行排序,具体取决于使用的构造方法。...,只需要更改compare方法中的o2.score-o1.score 发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/139499.html原文链接:https://
Java比较器 在Java中经常会涉及到对象数组的排序问题,那么就涉及到对象之间的比较问题。...实现此接口的对象可以用作有序映射中的键或有序集合中的元素,无需指定比较器。...Comparable 的典型实现:(默认都是从小到大排列的) String:按照字符串中字符的Unicode值进行比较 Character:按照字符的Unicode值来进行比较 数值类型对应的包装类以及...使用背景: 当元素没有实现java.lang.Comparable接口而又不方便改代码,或者是实现了Comparable接口,也指定了两个对象的比较大小的规则,但此时不想按照预定义的方法比较大小。...所以又增加了一个java.util.Comparator接口。强行对多个对象进行整体排序的比较。
概述: 要知道数组的长度是不可改变的 但是ArrayList集合的长度是可以随意变化的 1.创建 类型不能是基本数据类型 只能是引用数据类型 用基本数据类型的包装类就可以 //创建ArrayList集合...arrayList.add("第四个"); arrayList.add("第五个"); System.out.println(arrayList); //获取集合中的元素元素...String tow = arrayList.get(4); System.out.println(onw); System.out.println(tow); 4.删除集合中的元素...remove(); 它删除并返回删除的值 //创建ArrayList集合 ArrayList arrayList = new ArrayList(...arrayList.add("第四个"); arrayList.add("第五个"); System.out.println(arrayList); //删除集合中的元素
在 Java 中有多种方法可以比较日期,日期在计算机内部表示为(long型)时间点——自1970年1月1日以来经过的毫秒数。...在Java中,Date是一个对象,包含多个用于比较的方法,任何比较两个日期的方法本质上都会比较日期的时间。...Calender.after() 和 Calender.equals() 使用 getTime() 使用 Java 8 的 isBefore()、isAfter()、isEqual() 和 compareTo...这是对两种原始数据类型的比较,因此可以使用 和 == 来比较。 在比较日期之前,必须使用前面创建的 Date 对象中的数据来创建长整型。...() isAfter() isEqual() compareTo() 在 Java 8 中,可以使用新的 isBefore()、isAfter()、isEqual() 以及 compareTo() 来比较
提要 Map集合概述 Map K:键的类型 V:值的类型 把建映射到值的对象中,每一个建最多映射到一个值 不能有重复的键 创建 具体的实现类是:HashMap 用多态的方式创建 //创建Map...集合 Map hashMap = new HashMap(); 添加元素 put() 切记 K 重复会替换之前的值 //创建...也就是集合中键值对的个数 size() 返回 int 类型 //创建Map集合 Map hashMap = new HashMap<String...//添加元素 map.put("壹","一"); map.put("贰","二"); map.put("弎","三"); //判断集合中是否有指定的键...//添加元素 map.put("壹","一"); map.put("贰","二"); map.put("弎","三"); //判断集合中是否有指定的值
一.比较器的使用 private static class Student{ int age; String name; int height; public Student...students){ System.out.println(student); } 定义一个student类,然后定义一个isIncrease类继承Comparator接口,注意这里的泛型的类型要添加上...Student 如果返回的是负数,那么对象o1在前面; 如果返回的是正数,那么对象o2在前面; 上面程序输出: Student{age=12, name='lvachao', height=23} Student
java集合概述 Java 集合可分为 Collection 和 Map 两种体系 Collection接口:单列数据,定义了存取一组对象的方法的集合 List:元素有序(指的是存储时,与存放顺序保持一致...正常情况下,大多数的Java程序员使用ArrayList而不是Vector,因为同步完全可以由程序员自己来控制。Vector每次扩容请求其大小的2倍空间,而ArrayList是1.5倍。...Set 判断两个对象是否相同不是使用 == 运算符,而是根据 equals() 方法 Set实现类之一:HashSet HashSet 是 Set 接口的典型实现,大多数时候使用 Set 集合时都使用这个实现类...要实现定制排序,需要将实现Comparator接口的实例作为形参传递给TreeSet的构造器。 此时,仍然只能向TreeSet中添加类型相同的对象。否则发生ClassCastException异常。...允许使用null键和null值,与HashSet一样,不保证映射的顺序。 所有的key构成的集合是Set:无序的、不可重复的。
一、Java中的集合 集合接口 集合框架定义了一些接口。...Enumeration 通过它可以枚举(一次获得一个)对象集合中的元素。这个传统接口已被迭代器取代。 Set和List的区别 Set接口实例存储的是无序的,不重复的数据。...---- 集合实现类(集合类) Java提供了一套实现了Collection接口的标准集合类。其中一些是具体类,这些类可以直接拿来使用,而另外一些是抽象类,提供了接口的部分实现。...BitSet 一个Bitset类创建一种特殊类型的数组来保存位值。BitSet中数组大小会随需要增加。 迭代器 通常情况下,你会希望遍历一个集合中的元素。例如,显示集合中的每个元素。...comparable是在java.lang包下的,而Comparator是在java.util包下 有两种比较器Comparable和Comparator,后者相比前者有如下优点: 如果实现类没有实现
集合 1.1 为什么使用集合 开发中会使用大量相同数据类型的情况。如果使用数组来解决问题 1. 数组能够使用的方法非常少,功能方法需要程序员自己完成。 2. 数据类型单一化,不支持多种情况。...数组容量不可以更改。 集合为解决问题而生: 1. 方法多种多样,基本功能完善 2. 数据类型支持多样化,但是又不失数据类型一致要求 3....容量可以变,并且不用开发者操心 1.2 集合架构 Java中集合的【总接口】Collection。...> c); 判断集合c是不是当前集合的子集合 以下是代码的实现: 注意导包,之前的部分代码也需要导包 就是这个: import java.util.ArrayList; import java.util.Collection...Comparable接口由存储元素对应的类遵从,完成该方法 Comparator接口使用 interface Comparator { int compare(T o1, T o2); } 需要完成一个自定义比较器类对象
Linux 的 I/O 调度器是一个以块式 I/O 访问存储卷的进程,有时也叫磁盘调度器。...Linux I/O 调度器的工作机制是控制块设备的请求队列:确定队列中哪些 I/O 的优先级更高以及何时下发 I/O 到块设备,以此来减少磁盘寻道时间,从而提高系统的吞吐量。...目前 Linux 上有如下几种 I/O 调度算法: noop – 通常用于内存存储的设备。 cfq – 完全公平调度器。进程平均使用IO带宽。... anticipatory deadline [cfq] 如何改变硬盘设备 I/O 调度器 (adsbygoogle = window.adsbygoogle || []).push(...{}); 使用如下指令: # echo {SCHEDULER-NAME} > /sys/block//queue/scheduler 比如设置 noop 调度器: # echo noop > /sys
1.Collection接口 Collection是最基本的集合接口,声明了适用于JAVA(List和Set)集合的通用方法 collection接口的方法:add()、clear()、iterator...hashCode() equals() TreeSet:TreeSet类实现了SortedSet接口,能够对集合中的对象进行排序,使用二叉树结构。...原理:使用对象的比较方法,如果对象的比较方法返回为0,则视为元素重复,则不存储。 Set的用法:存放的是对象的引用,没有重复对象。...remove(键):删除元素,一次删一对 获取map集合中的所有的数据: 1.keySet():获取map中所有的键,方法返回set集合,因为map中的键是惟一的。...有了所有的键,便可以通过迭代器或者使用foreach取出其中所有的值。 2.entrySet():返回set集合,Set>。
HashSet类 HashSet是Set接口的典型实现,大多数时候使用Set集合时就是使用这个实现类。HashSet按Hash算法来存储集合中的元素,因此具有很好的存取和查找性能。...如果需要把某个类的对象保存到HashSet集合中,重写这个类的equals方法和hashCode方法时,应尽量保证两个对象通过equals发那个法比较返回true时,他们的hashCode方法返回值也相等...Java提供了一个Comparable接口,该接口里定义了一个compareTo(Object obj)方法,该方法返回一个整数值,实现该接口的类必须实现该方法,实现了该接口的类必须实现该方法,实现接口的类就可以比较大小了...当把一个对象添加进集合时,集合调用该对象的CompareTo(Object obj)方法与容器中的其他对象比较大小,然后根据红黑树结构中找到它的存储位置。如果两个对象相等则新对象无法加入到集合中。...EnumSet类没有暴露任何构造器来创建该类的实例,EnumSet类提供了以下类方法来创建EnumSet对象。
(Object value):查询Map中是否包含一个或多个value; Set entrySet():返回map中包含的键值对所组成的Set集合,每个集合都是Map.Entry对象。...Object put(Object key,Object value):添加一个键值对,如果集合中的key重复,则覆盖原来的键值对; void putAll(Map m):将Map中的键值对复制到本Map...Hashtable不允许使用null作为key和value,否则会引发异常,而HashMap可以; 和HashSet的关系 与HashSet集合不能保证元素顺序一样,HashMap和Hashtable也不能保证键值对的顺序...而判断value值相等的标准:只要两个对象通过equals方法比较返回true即可。 不能修改集合中的key,否则程序再也无法准确访问到Map中被修改过的key。...equal方法比较是相等的,但是通过==比较不相等,后面两个字符串在常量池中同一位置,所以使用==判断相等。
集合概述 集合到底是什么呢? 集合:集合是java中提供的一种容器,可以用来存储多个数据。 集合和数组既然都是容器,它们有啥区别呢? 数组的长度是固定的。集合的长度是可变的。...数组中存储的是同一类型的元素,可以存储基本数据类型值。集合存储的都是对象。而且对象的类型可以不一致。在开发中一般当对象多的时候,使用集合进行存储。...集合框架 JAVASE提供了满足各种需求的API,在使用这些API前,先了解其继承与接口操作架构,才能了解何时采用哪个类,以及类之间如何彼此合作,从而达到灵活应用。...其中,最上层灰色框里填写的都是接口类型,第二层里填写的都是具体的实现类。 集合本身是一个工具,它存放在java.util包中。在Collection接口定义着单列集合框架中最最共性的内容。...public Object[] toArray(): 把集合中的元素,存储到数组中。
实际上,不可修改集合通常是可修改集合的包装器,其他代码仍然可以访问和修改被包装的可修改集合。通常需要使用集合一些时间才能在一定程度上理解不可修改集合和不可变集合。...3 使用 Java 集合的方法 JCF 中的每一个接口,包括 java.util.Collection,都提供了特定的方法用于访问和操作集合的各个元素。...需要注意的是,当集合中有重复元素时,移除只会影响元素的单个实例; equals(Collection object)——比较对象与集合是否等价; clear()——删除集合中的所有元素。...Collections Framework 试图通过使用同步包装器在并行处理期间防止线程不一致。虽然包装器可以让集合变成线程安全的,从而实现更高效的并行处理,但它可能会产生不良的性能影响。...经验法则是,对于较低的计算需求,包含 10000 个元素的数据集是使用并行处理的基线。 除此之外,还有其他更高级的方法来优化 Java 集合中的并行处理。
大家好,又见面了,我是你们的朋友全栈君。...Java集合类Collection,它是一个接口,他有两个子接口List和Map,Collection主要方法 boolean add(E e); boolean addAll(Collection c); // 参考Arrays.sort E get(int index); // 获取元素的值 E set(int index, E element); // 设置元素的值 int...indexOf(Object o); // 找o的位置 int lastIndexOf(Object o); // 最后一个匹配o的位置 List subList(int fromIndex...value * 10/100; // value减少百分之 10 }); map.replaceAll((key, value) -> value.toUpperCase()); // 将所有的值更改为大写
集合类中主要有几种接口? Collection:是集合List、Set、Queue的最基本的接口。 Iterator:迭代器,可以通过迭代器遍历集合中的内容。 Map:是映射表的基础接口。...集合中泛型的优点 保证了类型的安全性:泛型约束了变量的类型,保证了类型的安全性。 避免了不必要得装箱、拆箱的操作,提高了程序的性能:泛型变量固定了类型,在使用时就已经知道是值类型还是引用类型。...如何选用集合类 -- 需要根据键值对获取元素则采用Map接口下的集合 需要排序时选用TreeMap 无需排序时选用HashMap 需要保证线程安全可以采用ConcurrentHashMap -- 只需存放元素则采用...数据总是从Channel通道中读取到Buffer缓冲区中,或者从Buffer缓冲区中写入到Channel通道中。Selector监视器则用于监听多个通道的事件,如:连接打开、数据到达等。...什么是Java序列化?如何实现Java序列化? 序列化: 是一种用来处理对象流的机制,而所谓的对象流就是将对象的内容进行流化,可以对流化后的对象进行对写操作,也可将流化后的对象传输于网路之间。
Queue 是一端进另一端出的线性数据结构;而 Deque 是两端都可以进出的。 Queue Java 中的 这个 Queue 接口稍微有点坑,一般来说队列的语义都是先进先出(FIFO)的。...; 如果想实现「栈」的语义,就使用 ArrayDeque。...在实现普通队列时,如何选择用 LinkedList 还是 ArrayDeque 呢?...那如果是一个很资深的面试官问你,什么情况下你要选择用 LinkedList 呢? 答:Java 6 以前。。。因为 ArrayDeque 在 Java 6 之后才有的。。...有很多高频面试题都是要用到栈的,比如接水问题,虽然最优解是用双指针,但是用栈是最直观的解法也是需要了解的,之后有机会再专门写吧。 那在 Java 中是怎么实现栈的呢?
面对并发修改,快速失败迭代器通过抛出ConcurrentModificationException快速失败,而不是冒着在将来不确定的时间出现任意的、非确定性的风险。...一、此异常主要在以下两种情况下发生 1、当快速失败迭代器在同一个线程中迭代集合时,集合使用集合的方法而非迭代器方法修改。...,而另一个线程正在使用快速失败迭代器迭代它。...(2)对于任何修改,不要使用Collection.remove()方法,而应始终使用迭代器的iterator.remove()方法。...,而应使用并发集合中的快速安全(fail-safe)迭代器。
领取专属 10元无门槛券
手把手带您无忧上云