------- android培训java培训、期待与您交流!
----------

集合框架的工具类:

       Collections : 集合框架的工具类。里面定义的都是静态方法。

Collections和Collection有什么区别?

Collection是集合框架中的一个顶层接口,它里面定义了单列集合的共性方法。它有两个常用的子接口,

List :对元素都有定义索引。有序的。可以重复元素。

Set :不可以重复元素。无序。

 

Collections是集合框架中的一个工具类。该类中的方法都是静态的

提供的方法中有可以对list集合进行排序,二分查找等方法。

通常常用的集合都是线程不安全的。因为要提高效率,多线程操作这些集合时,可以通过该工具类中的同步方法,将线程不安全的集合,转换成安全的。

常用方法:

sort(List<T> list) 根据元素的自然顺序进行排列

sort(List<T> list, Comparator<? super T> c)  根据指定比较器产生的顺序对指定列表进行排序。

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List; /**
* sort方法演示:
*
*/
public class SortDemo
{
public static void main(String[] args)
{
List<String> al = new ArrayList<String>(); al.add("013");
al.add("03");
al.add("002");
System.out.println(al); Collections.sort(al);
System.out.println(al); Collections.sort(al,new LenCompare());
System.out.println(al);
}
} //定义一个比较器,按照长度排序
class LenCompare 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);
}
}

binarySearch(List<? extends comparable<? super T>> list, T key)   使用二分搜索法搜索指定列表,以获得指定对象。

binarySearch(List<? extends T> list, T key, Comparator<? super T> c) 使用二分搜索法搜索指定列表,以获得指定对象。

import java.util.ArrayList;
import java.util.Collections;
import java.util.List; /**
* binarySearch方法演示:
*
*/
public class BinarySearchDemo
{
public static void main(String[] args)
{
List<String> al = new ArrayList<String>(); al.add("01");
al.add("02");
al.add("03");
System.out.println(al); int i = Collections.binarySearch(al, "03");
System.out.println(i);
}
}

max(Collection<? extends T> coll)  根据元素的自然顺序,返回给定 collection 的最大元素。

max(Collection<? extends T> coll, Comparator<? super T> comp)   根据指定比较器产生的顺序,返回给定 collection 的最大元素。

min(Collection<? extends T> coll)  根据元素的自然顺序 返回给定 collection 的最小元素。

min(Collection<? extends T> coll, Comparator<? super T> comp)   根据指定比较器产生的顺序,返回给定 collection 的最小元素。

import java.util.ArrayList;
import java.util.Collections;
import java.util.List; /**
* 最值方法演示:
*
*/
public class MaxMinDemo
{
public static void main(String[] args)
{
List<String> al = new ArrayList<String>(); al.add("01");
al.add("02");
al.add("03");
System.out.println(al); String max = Collections.max(al);
System.out.println("max= "+max); String min = Collections.min(al);
System.out.println("min= "+min);
}
}

shuffle(List<?> list) 使用默认随机源对指定列表进行置换。

shuffle(List<?> list, Random rnd) 使用指定的随机源对指定列表进行置换。

import java.util.ArrayList;
import java.util.Collections;
import java.util.List; /**
* shuffle方法演示:
*
*/
public class ShuffleDemo
{
public static void main(String[] args)
{
List<String> al = new ArrayList<String>(); al.add("01");
al.add("02");
al.add("03");
System.out.println(al); Collections.shuffle(al);
System.out.println(al);
}
}

reverseOrder() 返回一个比较器,它强行逆转实现了 Comparable 接口的对象 collection 的自然顺序。

reverseOrder(Comparator<T> cmp) 返回一个比较器,它强行逆转指定比较器的顺序。

import java.util.Collections;
import java.util.Comparator;
import java.util.Iterator;
import java.util.TreeSet; /**
* 反转演示1:
*
*/
public class OrderDemo
{
public static void main(String[] args)
{
TreeSet<String> s = new TreeSet<String>(Collections.reverseOrder(new LenCompare())); s.add("aaa");
s.add("aws");
s.add("aa");
s.add("diea"); for (Iterator<String> it = s.iterator();it.hasNext(); )
{
System.out.println(it.next());
}
}
} class LenCompare 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);
}
}

reverse(List<?> list) 反转指定列表中元素的顺序。

replaceAll(List<T> list, T oldVal, T newVal)  使用另一个值替换列表中出现的所有某一指定值。

import java.util.ArrayList;
import java.util.Collections;
import java.util.Iterator;
import java.util.List; /**
* 反转演示2:
*
*/
public class OrderDemo
{
public static void main(String[] args)
{
List<String> s = new ArrayList<String>(); s.add("aaa");
s.add("aws");
s.add("aa");
s.add("diea"); Collections.reverse(s); Collections.replaceAll(s,"aa","bb"); for (Iterator<String> it = s.iterator();it.hasNext(); )
{
System.out.println(it.next());
} }
}

fill(List<? super T> list, T obj) 使用指定元素替换指定列表中的所有元素。

import java.util.ArrayList;
import java.util.Collections;
import java.util.Iterator;
import java.util.List; /**
* fill方法演示:
*
*/
public class FillDemo
{
public static void main(String[] args)
{
List<String> s = new ArrayList<String>(); s.add("aaa");
s.add("aws");
s.add("aa");
s.add("diea"); Collections.fill(s,"3c"); for (Iterator<String> it = s.iterator();it.hasNext(); )
{
System.out.println(it.next());
}
}
}

Arrays:

          用于操作数组的工具类。里面都是静态方法。

asList:   将数组变成list集合

把数组变成list集合有什么好处? 

         

      可以使用集合的思想和方法来操作数组中的元素。 

 

      注意:将数组变成集合,不可以使用集合的增删方法。因为数组的长度是固定。

        contains。

        get

        indexOf()

        subList(); 

 

      如果增删会反生UnsupportedOperationException,

如果数组中的元素都是对象。那么变成集合时,数组中的元素就直接转成集合中的元素。

如果数组中的元素都是基本数据类型,那么会将该数组作为集合中的元素存在。

import java.util.Arrays;
import java.util.List; /**
*
* Arrays演示:
*
*/
public class ArraysDemo
{
public static void main(String[] args)
{
String[] arr = {"abc","cc","kkkk"}; List<String> list = Arrays.asList(arr); System.out.println("contains:"+list.contains("cc"));
System.out.println(list);
}
}

集合变数组:

Collection接口中的toArray方法。

 

        1,指定类型的数组到底要定义多长呢?

当指定类型的数组长度小于了集合的size,那么该方法内部会创建一个新的数组。长度为集合的size。

当指定类型的数组长度大于了集合的size,就不会新创建了数组。而是使用传递进来的数组。

所以创建一个刚刚好的数组最优。

        

        2,为什么要将集合变数组?

为了限定对元素的操作。不需要进行增删了。

import java.util.ArrayList;
import java.util.Arrays; /**
* 集合变数组演示
*/
public class CollectionToArray
{
public static void main(String[] args)
{
ArrayList<String> al = new ArrayList<String>(); al.add("a");
al.add("b");
al.add("c"); String[] arr = al.toArray(new String[al.size()]);
System.out.println(Arrays.toString(arr));
}
}

------- android培训java培训、期待与您交流!
----------

黑马程序员——JAVA基础之Collections和Arrays,数组集合的转换的更多相关文章

  1. 黑马程序员Java基础班+就业班课程笔记全发布(持续更新)

    正在黑马学习,整理了一些课程知识点和比较重要的内容分享给大家,也是给自己拓宽一些视野,仅供大家交流学习,大家有什么更好的内容可以发给我 ,现有黑马教程2000G  QQ 1481135711 这是我总 ...

  2. 黑马程序员----java基础笔记中(毕向东)

    <p>------<a href="http://www.itheima.com" target="blank">Java培训.Andr ...

  3. 黑马程序员----java基础笔记上(毕向东)

    ------Java培训.Android培训.iOS培训..Net培训.期待与您交流! ------- 笔记一共记录了毕向东的java基础的25天课程,分上.中.下 本片为上篇,涵盖前10天课程 1. ...

  4. 黑马程序员——JAVA基础之泛型和通配符

    ------- android培训.java培训.期待与您交流! ---------- 泛型:            JDK1.5版本以后出现新特性.用于解决安全问题,是一个类型安全机制. 泛型好处: ...

  5. 黑马程序员——JAVA基础之简述面向对象,类,变量,匿名对象

    ------- android培训.java培训.期待与您交流! ---------- 面向对象: 面向对象是相对面向过程而言 面向对象和面向过程都是一种思想 面向过程 强调的是功能行为 面向对象 将 ...

  6. 黑马程序员——JAVA基础之语法、命名规则

    ------- android培训.java培训.期待与您交流! ---------- 1.java语言组成:关键字,标识符,注释,常量和变量,运算符,语句,函数,数组. 2.java关键字:被Jav ...

  7. 黑马程序员——JAVA基础之函数,重载,内存结构

      ------- android培训.java培训.期待与您交流! ---------- 函数: 什么是函数? • 函数就是定义在类中的具有特定功能的一段独立小程序. • 函数也称为方法. 函数的格 ...

  8. 黑马程序员——JAVA基础之File类,递归,打印流,合并切割流

    ------- android培训.java培训.期待与您交流! ---------- File类 用来将文件或者文件夹封装成对象 方便对文件与文件夹的属性信息进行操作. File对象可以作为参数传递 ...

  9. 黑马程序员——JAVA基础之多线程的安全问题

    ------- android培训.java培训.期待与您交流! ---------- 导致多线程出现问题的一个特殊的状态:就绪.具备了执行资格,但是还没有获取资源. 导致安全问题的出现的原因: 1. ...

随机推荐

  1. [转] Android应用程序与SurfaceFlinger服务的关系概述和学习计划

    转自:Android应用程序与SurfaceFlinger服务的关系概述和学习计划 SurfaceFlinger服务负责绘制Android应用程序的UI,它的实现相当复杂,要从正面分析它的实现不是一件 ...

  2. Android 导入jar包 so模块--导入放置的目录

    Android视图下 app目录下的jniLibs 对应Project 视图app下的libs目录 把jar包或者带so文件的文件夹(一般以处理器型号命名如:arbeabi  arm64-v8a)复制 ...

  3. php的查询数据

    php中 连接数据库,通过表格形式输出,查询数据.全选时,下面的分选项都选中;子选项取消一个时,全选按钮也取消选中. <!DOCTYPE html PUBLIC "-//W3C//DT ...

  4. Core Animation系列之CADisplayLink

    一直以来都想好好学习下CoreAnimation,奈何涉及的东西太多,想要一次性全部搞定时间上不允许,以后会断断续续的补全.最近项目里用到了CADisplayLink,就顺便花点时间看了看. 一.简介 ...

  5. iOS: 枚举类型 enum,NS_ENUM,NS_OPTIONS

    一般情况下,我们采用C风格的enum关键字可以定义枚举类型. enum{ UIViewAnimationTransitionNone, UIViewAnimationTransitionFlipFro ...

  6. 首席技术官 (CTO) 比普通程序员强在哪

    互联网的蓬勃发展,让无数的程序员身价水涨船高,都变成了「香饽饽」,更有了不少「创业」,「当上 CTO,迎娶白富美的传说」.都说不想当元帅的士兵不是好士兵,我觉得这件事见仁见智,但提升自己的价值,让自己 ...

  7. javaweb-dbutils

    package cn.itcast.demo; import java.io.File;import java.io.FileNotFoundException;import java.io.File ...

  8. HDU5763 another meaning -(KMP+DP)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5763 思路:dp[i]表示前i个字符组成的字符串所表示的意思数量,则当匹配时dp[i]=dp[i-1] ...

  9. BZOJ3028 食物 (生成函数)

    首先 1+x+x^2+x^3+...+x^∞=1/(1-x) 对于题目中的几种食物写出生成函数 (对于a*x^b , a表示方案数 x表示食物,b表示该种食物的个数) f(1)=1+x^2+x^4+. ...

  10. HDU 5086

    http://acm.hdu.edu.cn/showproblem.php?pid=5086 求所有连续区间的数字和 本质是一个乘法原理,当前位置的数字出现次数=这个数之前的数字个数*这个数之后的数字 ...