JAVA基础知识之Collections工具类
排序操作
Collections提供以下方法对List进行排序操作
void reverse(List list):反转
void shuffle(List list),随机排序
void sort(List list),按自然排序的升序排序
void sort(List list, Comparator c);定制排序,由Comparator控制排序逻辑
void swap(List list, int i , int j),交换两个索引位置的元素
void rotate(List list, int distance),旋转。当distance为正数时,将list后distance个元素整体移到前面。当distance为负数时,将 list的前distance个元素整体移到后面。
下面简单演示Collections操作List
- package collection;
- import java.util.ArrayList;
- import java.util.Collections;
- import java.util.Comparator;
- public class CollectionsTest {
- public static void main(String[] args) {
- ArrayList nums = new ArrayList();
- nums.add(8);
- nums.add(-3);
- nums.add(2);
- nums.add(9);
- nums.add(-2);
- System.out.println(nums);
- Collections.reverse(nums);
- System.out.println(nums);
- Collections.sort(nums);
- System.out.println(nums);
- Collections.shuffle(nums);
- System.out.println(nums);
- //下面只是为了演示定制排序的用法,将int类型转成string进行比较
- Collections.sort(nums, new Comparator() {
- @Override
- public int compare(Object o1, Object o2) {
- // TODO Auto-generated method stub
- String s1 = String.valueOf(o1);
- String s2 = String.valueOf(o2);
- return s1.compareTo(s2);
- }
- });
- System.out.println(nums);
- }
- }
执行结果,
- [8, -3, 2, 9, -2]
- [-2, 9, 2, -3, 8]
- [-3, -2, 2, 8, 9]
- [9, -2, 8, 2, -3]
- [-2, -3, 2, 8, 9]
查找,替换操作
int binarySearch(List list, Object key), 对List进行二分查找,返回索引,注意List必须是有序的
int max(Collection coll),根据元素的自然顺序,返回最大的元素。 类比int min(Collection coll)
int max(Collection coll, Comparator c),根据定制排序,返回最大元素,排序规则由Comparatator类控制。类比int min(Collection coll, Comparator c)
void fill(List list, Object obj),用元素obj填充list中所有元素
int frequency(Collection c, Object o),统计元素出现次数
int indexOfSubList(List list, List target), 统计targe在list中第一次出现的索引,找不到则返回-1,类比int lastIndexOfSubList(List source, list target).
boolean replaceAll(List list, Object oldVal, Object newVal), 用新元素替换旧元素。
下面示范简单用法,
- package collection.collections;
- import java.util.ArrayList;
- import java.util.Collections;
- public class CollectionsTest {
- public static void main(String[] args) {
- ArrayList num = new ArrayList();
- num.add(3);
- num.add(-1);
- num.add(-5);
- num.add(10);
- System.out.println(num);
- System.out.println(Collections.max(num));
- System.out.println(Collections.min(num));
- Collections.replaceAll(num, -1, -7);
- System.out.println(Collections.frequency(num, 3));
- Collections.sort(num);
- System.out.println(Collections.binarySearch(num, -5));
- }
- }
执行结果,
- [3, -1, -5, 10]
- 10
- -5
- 1
- 1
同步控制
Collections中几乎对每个集合都定义了同步控制方法,例如 SynchronizedList(), SynchronizedSet()等方法,来将集合包装成线程安全的集合。下面是Collections将普通集合包装成线程安全集合的用法,
- package collection.collections;
- import java.util.ArrayList;
- import java.util.Collection;
- import java.util.Collections;
- import java.util.HashMap;
- import java.util.HashSet;
- import java.util.List;
- import java.util.Map;
- import java.util.Set;
- public class SynchronizedTest {
- public static void main(String[] args) {
- Collection c = Collections.synchronizedCollection(new ArrayList());
- List list = Collections.synchronizedList(new ArrayList());
- Set s = Collections.synchronizedSet(new HashSet());
- Map m = Collections.synchronizedMap(new HashMap());
- }
- }
设置不可变(只读)集合
Collections提供了三类方法返回一个不可变集合,
emptyXXX(),返回一个空的只读集合(这不知用意何在?)
singleXXX(),返回一个只包含指定对象,只有一个元素,只读的集合。
unmodifiablleXXX(),返回指定集合对象的只读视图。
用法如下,
- package collection.collections;
- import java.util.Collection;
- import java.util.Collections;
- import java.util.HashMap;
- import java.util.List;
- import java.util.Map;
- import java.util.Set;
- public class UnmodifiableCollection {
- public static void main(String[] args) {
- List lt = Collections.emptyList();
- Set st = Collections.singleton("avs");
- Map mp = new HashMap();
- mp.put("a",100);
- mp.put("b", 200);
- mp.put("c",150);
- Map readOnlyMap = Collections.unmodifiableMap(mp);
- //下面会报错
- lt.add(100);
- st.add("sdf");
- mp.put("d", 300);
- }
- }
执行结果,
- Exception in thread "main" java.lang.UnsupportedOperationException
- at java.util.AbstractList.add(Unknown Source)
- at java.util.AbstractList.add(Unknown Source)
- at collection.collections.UnmodifiableCollection.main(UnmodifiableCollection.java:22)
JAVA基础知识之Collections工具类的更多相关文章
- Java基础Map接口+Collections工具类
1.Map中我们主要讲两个接口 HashMap 与 LinkedHashMap (1)其中LinkedHashMap是有序的 怎么存怎么取出来 我们讲一下Map的增删改查功能: /* * Ma ...
- Java:集合,Collections工具类用法
Collections工具类提供了大量针对Collection/Map的操作,总体可分为四类,都为静态(static)方法: 1. 排序操作(主要针对List接口相关) reverse(List li ...
- Java集合框架:Collections工具类
java.util.Collections工具类提供非常多实用的方法.使得程序员操作集合类的时候更加的方便easy,这些方法都是静态的. 整个Collections工具类源代码几乎相同有4000行.我 ...
- Java可变参数与Collections工具类使用了解
今天发现jdk1.5后增加了个可变参数,以前还一直不晓得 public static void main(String[] args) { System.out.println(getNum(1,2, ...
- Java集合(1):Collections工具类中的static方法
与Arrays一样,Collections类中也有一些实用的static方法. (1) 排序操作 reverse(List list):反转指定List集合中元素的顺序 shuffle(List li ...
- JAVA基础学习day17--集合工具类-Collections
一.Collection简述 1.1.Collection与Collections的区别 Collections是集合的静态工具类 Collection:是集合的顶级接口 二.Sort 2.1.sor ...
- java基础37 集合框架工具类Collections和数组操作工具类Arrays
一.集合框架工具类:Collections 1.1.Collections类的特点 该工具类中所有的方法都是静态的 1.2.Collections类的常用方法 binarySearch(List< ...
- Java中的集合Collections工具类(六)
操作集合的工具类Collections Java提供了一个操作Set.List和Map等集合的工具类:Collections,该工具类里提供了大量方法对集合元素进行排序.查询和修改等操作,还提供了将集 ...
- JAVA基础学习day18--常用工具类
一.System 1.1.概述 System 类包含一些有用的类字段和方法.它不能被实例化. 在 System 类提供的设施中,有标准输入.标准输出和错误输出流:对外部定义的属性和环境变量的访问:加载 ...
随机推荐
- leetcode98 Validate Binary Search Tree
题目: Given a binary tree, determine if it is a valid binary search tree (BST). Assume a BST is define ...
- leetcode-5 最长回文子串(动态规划)
题目要求: * 给定字符串,求解最长回文子串 * 字符串最长为1000 * 存在独一无二的最长回文字符串 求解思路: * 回文字符串的子串也是回文,比如P[i,j](表示以i开始以j结束的子串)是回文 ...
- 在自定义的UINavigationController中设置背景图片
//这个方法中设置 + (void)initialize { UINavigationBar *bar = [UINavigationBar appearance]; [bar setBackgrou ...
- CentOS 7 内核更新后删除旧内核
0.当前 # uname -sr Linux -.el7.x86_64 1.搜索查询 # rpm -q kernel kernel--.el7.x86_64 kernel--.el7.x86_64 k ...
- SharedPreferences 轻型的数据存储方式
//初始化,(名字,隐私或公开) SharedPreferences openTimes=getSharedPreferences("openTimes",0); //提交保存数据 ...
- mysql 线程池 数据库连接池
当客户端请求的数据量比较大的时候,使用线程池可以节约大量的系统资源,使得更多的CPU时间和内存可以高效地利用起来.而数据库连接池的使用则将大大提高程序运行效率,同时,我们可以通过其自身的管理机制来监视 ...
- 关于mybatis 在C#.Net中批量增,删,改
发现很久没有更新空间里的日志了,有时候实在忙没有时间记录,有时候又觉得自己整理的不够清晰,还是缓缓在记录吧. 下面直接进入正题 对于急需方法的阅读者 可以直接转至代码以下忽略 对于数据库进行操作的类 ...
- android模拟器启动没有拨号功能
网上查询了很多资料, 其中一位网友给出的结论是android 4.3模拟器的bug, 如果在通讯录中添加好友,也是可以进行拨号的. 总结: 自认为是SDK安装程序不完整或设置AVD模拟器的时候设置项出 ...
- Subversion简明手册--使用hook svn
使用 hook ,为了方便管理员 控制提交的过程 Subversion 提供了 hook 机制.当特定的 事件发生时,相应的 hook 会被调用, hook 其实就相当于特定 事件的处理函数.每个 h ...
- T-sql语句中GO的作用及语法【转】
1. 作用: 向 SQL Server 实用工具发出一批 Transact-SQL 语句结束的信号.2. 语法:一批 Transact-SQL 语句GO如Select 1Select 2Select ...