Map知识点Utilities后续整理(关于Collections,Array,增强for循环)
一:介绍
1.介绍
里面都是静态方法。
可以直接调用。
Collections是集合框架中的一个工具类。该类中的方法都是静态的
提供的方法中有可以对list集合进行排序,二分查找等方法。
通常常用的集合都是线程不安全的。因为要提高效率。 如果多线程操作这些集合时,可以通过该工具类中的同步方法,将线程不安全的集合,转换成安全的。
二:Collections程序
1.sort的使用
除了使用自然排序,还可以使用的是添加比较器。
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
public class Test66 {
public static void main(String[] args) {
sortDemo1();
}
public static void sortDemo1(){
ArrayList<String> al=new ArrayList<>();
al.add("abbdd");
al.add("o");
al.add("bcd");
al.add("bqpr");
System.out.println("随机打印:"+al);
Collections.sort(al); //基础的自然排序
System.out.println("基础的自然排序"+al);
Collections.sort(al,new StrLenComparator());//先根据长度排序
System.out.println("先根据长度排序"+al); //
}
}
class StrLenComparator implements Comparator<String>{
public int compare(String s1, String s2) {
if(s1.length()>s2.length()){
return 1;
}
if(s1.length()<s2.length()){
return -1;
}
return s1.compareTo(s2);
} }
2.运行程序

3.binarySearch方法
import java.util.ArrayList;
import java.util.Collections; public class Test67 {
public static void main(String[] args) {
int index=halfDemo1();
System.out.println("index="+index);
}
public static int halfDemo1(){
ArrayList<String> al=new ArrayList<>();
al.add("abbdd");
al.add("o");
al.add("bcd");
al.add("bqpr");
Collections.sort(al);
int index=Collections.binarySearch(al, "bqpr");//需要已排序
return index;
}
}
4.运行的结果

5.max的使用
依然分两种使用方式。
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List; public class Test68 { public static void main(String[] args) {
maxDemo();
}
public static void maxDemo(){
List<String> list = new ArrayList<String>();
list.add("abcd");
list.add("aaa");
list.add("zz");
list.add("kkkkk");
list.add("qq");
list.add("z");
Collections.sort(list);
System.out.println(list);
//基础的max
String max1 = Collections.max(list);
System.out.println("max1="+max1);
//调用比较器的max
String max2 = Collections.max(list,new StrLenComparator2());
System.out.println("max2="+max2);
} }
class StrLenComparator2 implements Comparator<String>{
public int compare(String s1, String s2) {
if(s1.length()>s2.length()){
return 1;
}
if(s1.length()<s2.length()){
return -1;
}
return s1.compareTo(s2);
} }
6.reverseOrder方法
使用StrLenComparator比较器之后在进行逆序。
就是在reverse之后在逆向排序输出。
import java.util.Collections;
import java.util.Iterator;
import java.util.TreeSet;
public class Test69 {
public static void main(String[] args) {
orderDemo();
}
public static void orderDemo(){
TreeSet<String> ts = new TreeSet<String>(Collections.reverseOrder(new StrLenComparator()));
ts.add("abcde");
ts.add("aaa");
ts.add("k");
ts.add("cc");
Iterator it = ts.iterator();
while(it.hasNext())
{
System.out.println(it.next());
}
}
}
7.运行结果

8.toArray方法
为什么要将集合变数组?
为了限定对元素的操作。不需要进行增删了。
import java.util.ArrayList;
import java.util.Arrays; public class Test70 {
public static void main(String[] args) {
ArrayList<String> al = new ArrayList<String>();
al.add("abc1");
al.add("abc2");
al.add("abc3");
String[] arr = al.toArray(new String[al.size()]);
System.out.println(Arrays.toString(arr));
} }
9.运行结果

三:Arrays程序
1.toString
import java.util.Arrays;
public class Test71 {
public static void main(String[] args) {
int[] arr={1,4,2,7,4};
String str=Arrays.toString(arr);
System.out.println("str="+str);
}
}
2.运行结果

3.asList
将数组变成list集合
注意:将数组变成集合,不可以使用集合的增删方法。
import java.util.Arrays;
import java.util.List;
public class Test72 {
public static void main(String[] args) {
//int
int[] nums1 = {2,4,5};
List<int[]> li = Arrays.asList(nums1);
System.out.println(li);
//Integer
Integer[] nums2={3,6,5};
List<Integer> li2=Arrays.asList(nums2);
System.out.println(li2);
//String
String[] arr={"dsds","jun","opu"};
List<String> liArr=Arrays.asList(arr);
System.out.println(liArr); }
}
4.运行结果以及解析

四:增强for循环
1.String的
import java.util.ArrayList;
public class Test73 {
public static void main(String[] args) {
ArrayList<String> al = new ArrayList<String>();
al.add("abc1");
al.add("abc2");
al.add("abc3");
for(String s : al)
{
System.out.println(s);
}
System.out.println(al);
}
}
2.map
import java.util.HashMap;
import java.util.Map;
import java.util.Set; public class Test74 {
public static void main(String[] args) {
Map<Integer,String> hm=new HashMap<>();
hm.put(1, "zhangsan");
hm.put(2, "lisi");
hm.put(3, "wangwu");
//keySet
Set<Integer> keyset=hm.keySet();
for(Integer i : keyset){
System.out.println(hm.get(i));
}
//=============
System.out.println("==========");
//entrySet
for(Map.Entry<Integer, String> entry:hm.entrySet() ){
System.out.println(entry.getKey()+":"+entry.getValue());
} } }
3.运行结果

五:静态导入
1.格式
import static java.lang.System.*;//导入了System类中所有静态成员。
2.使用
out.println(“al”);
Map知识点Utilities后续整理(关于Collections,Array,增强for循环)的更多相关文章
- Java集合、Iterator迭代器和增强for循环整理
集合 集合,集合是java中提供的一种容器,可以用来存储多个数据. 数组的长度是固定的.集合的长度是可变的.集合中存储的元素必须是引用类型数据 1.1 ArrayList集合存储元素 pac ...
- JavaSE Collections类 , Iterator迭代器 , 增强for循环
Collections 它是集合的工具类,为集合体系扩展了一些其他的方法.类中都是静态的方法,可以使用类名直接调用. 可变参数 在JDK1.5之后,如果我们定义一个方法需要接受多个参数,并且多个参数类 ...
- 增强for循环、Map接口遍历、可变參数方法
增强for循环 1.for循环能做得事情.增强for循环大部分都能做(假设要想获得下标的时候就必须使用简单for循环了) 2.增强for有时候可以方便的处理集合遍历的问题,可是集合的标准遍历是使用迭代 ...
- 【java】Map、Set、List不同数据结构的各种不同循环迭代的效率对比,使用场景
Map.Set.List不同数据结构的各种不同循环迭代的效率对比,使用场景 引申一个地址:Map迭代的使用keySet和entitySet的效率
- Map的知识点梳理(不包含collections工具类)
一:基础公共方法(map不再是简单的加索引,可以直接命名key,通过key进行遍历) 1.常见的map子类 HashTable:底层是哈希表结构.不允许null键和null值,线程同步 HashMap ...
- 机器学习-Pandas 知识点汇总(吐血整理)
Pandas是一款适用很广的数据处理的组件,如果将来从事机械学习或者数据分析方面的工作,咱们估计70%的时间都是在跟这个框架打交道.那大家可能就有疑问了,心想这个破玩意儿值得花70%的时间吗?咱不是还 ...
- [Day20]Map接口、可变参数、Collections
1.Map接口-元素成对存在,每个元素由健与值两部分组成,通过键可以找所对应的值 1.1 Map子类 (1)HashMap<K,V>:存储数据所用的哈希表结构,元素的存取数据顺序不能保证一 ...
- 【js jQuery】map集合 循环迭代取值---以及 map、json对象、list、array循环迭代的方法和区别
后台给前台传来一个map @ResponseBody @RequestMapping(value = "getSys") public Map<Long,String> ...
- JavaScript 数组、字符串、Map、Set 方法整理
在线阅读 https://www.kancloud.cn/chenmk/web-knowledges/1080519 数组 isArray():Array.isArray(value) 用于检测变量是 ...
随机推荐
- 【BZOJ1304】[CQOI2009]叶子的染色(动态规划)
[BZOJ1304][CQOI2009]叶子的染色(动态规划) 题面 BZOJ 洛谷 题解 很简单. 设\(f[i][0/1/2]\)表示以\(i\)为根的子树中,还有颜色为\(0/1/2\)(\(2 ...
- 【转】crc16几种标准校验算法及c语言代码
一.CRC16校验码的使用 现选择最常用的CRC-16校验,说明它的使用方法. 根据Modbus协议,常规485通讯的信息发送形式如下: 地址 功能码 数据信息 校验码 1byte 1byte nby ...
- Atcoder Grand 006 C-Rabbit Exercise
题意: 数轴上有n只兔子,第i只兔子的坐标为xi. 有一组操作,这组操作的第i个操作是要让第ai只兔子等概率的跳到自己关于第ai+1或第ai-1只兔子的对称点. 进行K组操作,求每只兔子最后坐标的期望 ...
- [学习笔记]凸优化/WQS二分/带权二分
从一个题带入:[八省联考2018]林克卡特树lct——WQS二分 比较详细的: 题解 P4383 [[八省联考2018]林克卡特树lct] 简单总结和补充: 条件 凸函数,限制 方法: 二分斜率,找切 ...
- 各种遍历输出(经典版)----java基础总结
前言:关于共有3中遍历输出方式,很早之前我就想整理,无奈一直没有抽出时间,分别是传统的for循环遍历,迭代器Iterator,foreach,这次我通过测试代码,测试了一下. 先用一张草图,大概有个印 ...
- win32 ini
原文:https://www.cnblogs.com/qq78292959/archive/2012/06/10/2544389.html Windows操作系统专门为此提供了6个API函数来对配置设 ...
- Hadoop生态圈-Flume的组件之拦截器与选择器
Hadoop生态圈-Flume的组件之拦截器与选择器 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 本篇博客只是配置的是Flume主流的Interceptors,想要了解更详细 ...
- go语言学习之路(一)Hello World
为什么要使用 Go 语言?Go 语言的优势在哪里? 1.部署简单. 2.并发性好. 3.良好的语言设计. 4.执行性能好. Go环境搭建 Golang下载 国外镜像 https://www.gola ...
- JavaScript1.6数组新特性和JQuery的几个工具方法
JavaScript 1.6 引入了几个新的Array 方法,具体的介绍见:New in JavaScript 1.6 .这些方法已经被写进了ECMA262 V5.现代浏览器(IE9/Firefox/ ...
- 20155310 2016-2017-2 《Java程序设计》第五周学习总结
20155310 2016-2017-2 <Java程序设计>第五周学习总结 教材学习内容总结 •收集对象的行为,像是新增对象的add()方法.移除对象的remove()方法等,都是定义在 ...