Java:集合工具类-Collections
Java.util.Collections
集合框架工具类Collections,其方法都是静态的,本身没有构造函数。
常见方法:
static <T extends Comparable<? super T>> void sort(List<T> list)
package Day17;
import java.util.*;
public class CollectionsDemo {
public static void main(String[] args)
{
sortDemo();
}
public static void sortDemo()
{
List<String> list = new ArrayList<String>();
list.add("abcd");
list.add("aaa");
list.add("abzcd");
list.add("kkk");
list.add("qq");
System.out.println("排序前:"+list);
Collections.sort(list);
System.out.println("排序后:"+list);
}
}
运行结果:
排序前:[abcd, aaa, abzcd, kkk, qq]
排序后:[aaa, abcd, abzcd, kkk, qq]
static <T> void sort(List<T> list,Comparator<? super T>,c)加入比较器后的sort。
package Day17;
import java.util.*;
public class CollectionsDemo {
public static void main(String[] args)
{
sortDemo();
}
public static void sortDemo()
{
List<String> list = new ArrayList<String>();
list.add("abcd");
list.add("aaa");
list.add("abzcd");
list.add("kkk");
list.add("qq");
list.add("qq"); System.out.println("排序前:"+list);
Collections.sort(list,new StrLengComparator());
System.out.println("按照长度排序后:"+list);
}
}
class StrLengComparator implements Comparator<String>
{
public int compare(String s1,String s2)
{
if(s1.length()==s2.length())
return s1.compareTo(s2);
return s1.length()-s2.length();
}
}
运行结果:
排序前:[abcd, aaa, abzcd, kkk, qq, qq]
按照长度排序后:[qq, qq, aaa, kkk, abcd, abzcd]
public static <T extends Object & Comparable<? super T>> max(Collection<? extends T> coll)根据元素的自然顺序,返回给定的Collection的最大元素。Collection中的所有元素都必须实现Comparable接口。此外,Collection中的所有元素都必须是可相互比较的(也就是,对于collection中的任意e1和e2元素,e1.caompareTo(e2)不得抛出ClassCastException)。此方法在整个collection上进行迭代,所以他需要的时间与collection的大小成正比。
static <T> int binarySearch(List<? extends Comparable<? super T>> list, T key)使用二分搜索法搜索指定列表,以获得指定对象。(如果找不到该元素返回-index-1)
package Day17;
import java.util.*;
public class CollectionsDemo {
public static void main(String[] args)
{
binarySearchDemo();
}
public static void binarySearchDemo()
{
List<String> list = new ArrayList<String>();
list.add("abcd");
list.add("aaa");
list.add("abzcd");
list.add("kkk");
list.add("qq");
list.add("qq"); System.out.println("排序前:"+list);
int index = Collections.binarySearch(list,"abcd");//使用集合工具
System.out.println("index="+index);
int index_my = myBinarySearch(list,"abcd");//使用自定义的二分查找法
System.out.println("index_my="+index_my); }
public static int myBinarySearch(List<String> list, String key)
{
int max,min,mid;
max = list.size()-1;
min = 0;
while (min <= max )
{
mid = (max + min) >> 1;
int num = list.get(mid).compareTo(key);
if (num>0)
max = mid-1;
else if (num<0)
min = mid+1;
else
return mid;
}
return -min-1;//如果找不到返回-index-1
}
}
运行结果:
排序前:[abcd, aaa, abzcd, kkk, qq, qq]
index=0
index_my=0
上面如果使用自定义的比较器,则
package Day17;
import java.util.*;
public class CollectionsDemo {
public static void main(String[] args)
{
binarySearchDemo();
}
public static void binarySearchDemo()
{
List<String> list = new ArrayList<String>();
list.add("abcd");
list.add("aaa");
list.add("abzcd");
list.add("kkk");
list.add("qq");
list.add("qq"); System.out.println("排序前:"+list);
int index = Collections.binarySearch(list,"abcd");//使用集合工具
System.out.println("index="+index);
int index_my = myBinarySearch(list,"abcd",new StrLengComparator());//使用自定义的二分查找法
System.out.println("index_my="+index_my); }
public static int myBinarySearch(List<String> list, String key,Comparator cmp)
{
int max,min,mid;
max = list.size()-1;
min = 0;
while (min <= max )
{
mid = (max + min) >> 1;
int num = cmp.compare(list.get(mid),key);
if (num>0)
max = mid-1;
else if (num<0)
min = mid+1;
else
return mid;
}
return -min-1;//如果找不到返回-index-1
}
}
class StrLengComparator implements Comparator<String>
{
public int compare(String s1,String s2)
{
if(s1.length()==s2.length())
return s1.compareTo(s2);
return s1.length()-s2.length();
}
}
static <T> void fill(List<? super T> list, T obj>)使用指定元素替换指定列表中的所有元素。
package Day17;
import java.util.*; public class CollectionsDemo2 {
public static void main(String[] args){
List<String> list = new ArrayList<String>();
list.add("abcd");
list.add("aaa");
list.add("zz");
list.add("kkkk");
System.out.println("使用fill前:"+list);
Collections.fill(list, "pp");
System.out.println("使用fill后:"+list);
}
}
运行结果:
使用fill前:[abcd, aaa, zz, kkkk]
使用fill后:[pp, pp, pp, pp]
static <T> boolean replaceAll(List<T> list, T oldVal, T newVal),将List集合中的指定元素替换成新元素。
package Day17;
import java.util.*; public class CollectionsDemo2 {
public static void main(String[] args){
List<String> list = new ArrayList<String>();
list.add("abcd");
list.add("aaa");
list.add("zz");
list.add("kkkk");
System.out.println("使用replaceAll前:"+list);
//Collections.fill(list, "pp");
//System.out.println("使用fill后:"+list);
Collections.replaceAll(list,"aaa","zzz");
System.out.println("使用replaceAll后:"+list);
}
}运行结果:
使用replaceAll前:[abcd, aaa, zz, kkkk]
使用replaceAll后:[abcd, zzz, zz, kkkk]
static <T> Comparator <T> reverseOrder(),返回一个比较器,可以强行逆转使用了Comparable接口的对象collection的自然排序。
未使用reverseOrder前:
package Day17;
import java.util.*; public class CollectionsDemo3 {
public static void main(String[] args){
TreeSet<String> ts = new TreeSet<String>();
ts.add("abcde");
ts.add("aaa");
ts.add("kkk");
ts.add("ccc");
for (Iterator it = ts.iterator(); it.hasNext(); ){
System.out.println(it.next());
}
}
}
运行结果:
aaa
abcde
ccc
kkk
使用reverseOrder后:
package Day17;
import java.util.*; public class CollectionsDemo3 {
public static void main(String[] args){
TreeSet<String> ts = new TreeSet<String>(Collections.reverseOrder());
ts.add("abcde");
ts.add("aaa");
ts.add("kkk");
ts.add("ccc");
for (Iterator it = ts.iterator(); it.hasNext(); ){
System.out.println(it.next());
}
}
}
运行结果:
kkk
ccc
abcde
aaa
并且该方法的重载方法static <T> Collection<T> reverseOrder(Comparator<T> cmp),可以强行逆转指定比较器的顺序。
static <T> List<T> synchronizedList(List<T> list),返回指定列表的线程同步(线程安全)的列表。
Java:集合工具类-Collections的更多相关文章
- Java 集合工具类---------- Collections类
- Java从零开始学二十四(集合工具类Collections)
一.Collections简介 在集合的应用开发中,集合的若干接口和若干个子类是最最常使用的,但是在JDK中提供了一种集合操作的工具类 —— Collections,可以直接通过此类方便的操作集合 二 ...
- java之集合工具类Collections
Collections类简介 java.utils.Collections 是集合工具类,用来对集合进行操作.此类完全由在 collection 上进行操作或返回 collection 的静态方法组成 ...
- Java—集合工具类
集合中的元素工具类排序: Java提供了一个操作Set.List和Map等集合的工具类:Collections,该工具类提供了大量方法对集合进行排序.查询和修改等操作,还提供了将集合对象置为不可变.对 ...
- Java笔记(二十四)……集合工具类Collections&Arrays
Collections 集合框架的工具类,方法全部为静态 Collections与Collection的区别 Collection是集合框架的一个顶层接口,里面定义了单列集合的共性方法 Collect ...
- Java常用类(五)之集合工具类Collections
前言 Java提供了一个操作Set.List和Map等集合的工具类:Collections,该工具类提供了大量方法对集合进行排序.查询和修改等操作, 还提供了将集合对象置为不可变.对集合对象实现同步控 ...
- java的集合工具类Collections
集合框架的工具类. Collections:集合框架的工具类.里面定义的都是静态方法. Collections和Collection有什么区别? Collection是集合框架中的一个顶层接口,它里面 ...
- 吴裕雄--天生自然java开发常用类库学习笔记:集合工具类Collections
import java.util.Collections ; import java.util.List ; import java.util.Set ; public class Collectio ...
- [黑马程序员] 集合框架2——Map系 & 集合工具类(Collections、Arrays)
---------------------- ASP.Net+Android+IO开发..Net培训.期待与您交流! ---------------------- 0. 集合框架按其所实现的接口, 大 ...
随机推荐
- 20145320 《Java程序设计》第8周学习总结
20145320 <Java程序设计>第8周学习总结 教材学习内容总结 15.1日志 java.util.logging包提供了日志功能相关类与接口,不必额外配置日志组件,就可以在标准ja ...
- C#扩展特性
今天跟同事讨论技术,无意发现的C#3.0的一个新特性,高手可以直接忽略. 这个特性叫扩展,我觉得非常的方便所以就记录下来了.以下是我的测试代码: public static class test { ...
- SecureCRT使用小技巧
SecureCRT使用小技巧 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 欢迎加入:高级运维工程师之路 598432640 以前觉得xshell链接工具挺好的,看起来又好耍,图 ...
- JVM常见配置汇总
堆设置 -Xms:初始堆大小 -Xmx:最大堆大小 -XX:NewSize=n:设置年轻代大小 -XX:NewRatio=n:设置年轻代和年老代的比值.如:为3,表示年轻代与年老代比值为1:3,年轻代 ...
- Mac 使用笔记
说来惭愧,入手Mac已经快大半年了,但使用上一直是菜鸟. 下面是最近学习和用到的技巧,纪录如下,以后会不定期更新. 开启多个Terminal,这个简直是调程序必备. Command+N 打开新的Ter ...
- 《Vuser虚拟用户开发》读书笔记
学会了Vuser开发只是算了性能测试入了门.要做好性能测试还需要了解系统的功能,架构和设计测试用例. 脚本选用什么协议的依据是需要模拟的客户端与服务器之间的通信采用什么协议.与具体的开发技术并无直接的 ...
- Walls(floyd POJ1161)
Walls Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 7677 Accepted: 3719 Description ...
- 简单的计算最值的MapReduce程序
import java.io.IOException;import java.util.StringTokenizer;import java.util.*;import org.apache.had ...
- 批量运行R包
#批量运行包:all.pcg <- c("data.table","ggplot2","rmarkdown","tidyr& ...
- HDU3333 Turing Tree 树状数组+离线处理
Turing Tree Time Limit: 6000/3000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...