`
xiaoheihei888
  • 浏览: 1025 次
  • 性别: Icon_minigender_2
  • 来自: 北京
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

黑马程序员 总结<七>---> 面向对象之集合-工具类

 
阅读更多

-----------android培训java培训、java学习型技术博客、期待与您交流! ------------


第一节 Util 工具类


工具类的Collections和Arrays中的方法全是静态的,下面主要总结几个比较重要的方法。
一、Collections工具类:
在Collections工具类中很多方法是用于对List集合进行操作的,如比较,查找,随机排序等等
1、集合的各种方法:

1)查找:

T max(Collection<? extends T> coll) ---> 根据集合的自然顺序,获取coll集合中的最大元素

Tmax(Collection<? extends T> coll,Comparator<? super T> comp) ---> 根据指定比较器comp的顺序,获取coll集合中的最大元素

int binarySearch(Lsit<? extends Comparable<? super T>> list,Tkey) ---> 二分法搜索list集合中的指定对象

2)替换:

voidfill(List<? super T>list, Tobj) ---> 将list集合中的全部元素替换成指定对象obj

boolean replaceAll(List<T> lsit,T oldVal,T newVal) ---> 使用newVal替换list集合中的oldVal值

3)排序:

void shuffle(List<?> list) ---> 使用默认随机源对list集合中的元素进行随机排序

void sort(Lsit<T> list) ---> 根据自然顺序对list集合中的元素进行排序

voidsort(List<T> lsit,Comparator<? super T> c) ---> 根据指定比较器c的排序方式对list集合进行排序

4)反转

reverse(List<?> list) ---> 反转list集合中元素的顺序

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

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

示例:

	......
	public static void sop(Object obj)
	{
		System.out.println(obj);
	}
	//定义比较器
	class StrLenCom implements Comparator<String>
	{
		public int compare(String s1,String s2)
		{
			int n = new Integer(s1.length()).compareTo(new Integer(s2.length()));
			if (n == 0)
				return s1.compareTo(s2);
			return n;
		}
	}
	......
		List<String> list = new ArrayList<String>();
		list.add("abd");
		list.add("cd");
		list.add("f");
		list.add("yyyy");
		list.add("abd");
		//打印原集合
		sop(list);
		sop("--------------排序-------------------");
		//随机排序:
		Collections.shuffle(list);
		sop("随机排序:" + list);
		//对元素排序,存入的对象必须具备比较性
		Collections.sort(list);
		//打印新集合
		sop("自然排序后的集合元素:" + list);
		//按指定比较器顺序排序
		Collections.sort(list,new StrLenCom());
		sop("长度排序:" + list);
		sop("------------获取最大元素-----------------");
		//获取最大元素
		String max = Collections.max(list);
		sop("max = " + max);
		sop("--------------查找--------------------");
		int index = Collections.binarySearch(list,"acd");
		sop("二分法查找值:" + index);
		int ex = half(list,"acd");
		sop("二分法查找值:" + ex);
		Collections.sort(list,new StrLenCom());
		sop("排序后的集合元素:" + list);
		int x = half2(list,"acd",new StrLenCom());
		sop("二分法查找值:" + x);
		sop("---------------替换-反转----------------");
		//反转
		Collections.reverse(list);
		sop("反转后:" + list);
		//替换
		Collections.fill(list,"pp");
		sop("替换后:" + list);
	......

创建部分替换方法:

	//替换部分字符
	public static void fillPart(List<String> list,int start,int end,String str)
	{
		List<String> li = new ArrayList<String>();
		for(int i=start;i<end;i++)
		{
			li.add(list.get(i));
			list.remove(list.get(i));
		}
		sop(list);
		Collections.fill(li,str);
		list.addAll(start,li);
	}
}

二、Arrays工具类:

1、Lsit<T> asList(T... a) ---> 将数组转换为集合

注意:将数组转换成集合,不可使用集合的增删方法,因为数组的长度是固定的,如果进行增删操作,则会产生UnsupportedOperationException的编译异常。

a.如果数组中的元素都是对象,则变成集合时,数组中的元素就直接转为集合中的元素

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

2、binarySearch():查找方法,fill():替换方法,sort():排序方法等

特点:可对数组元素进行相应操作,可以接受除boolean之外的其他各种基本数据类型及有序的引用类型数组的参数,且还可以对指定元素的范围,并可根据指定比较器进行相应的操作

如:sort(T[] a,Comparator<? super T> c)

fill(int[]a,int from,int to)等

3、String toString() 可以接收各种数组类型参数,并返回指定数组内容的字符串表现形式

4、集合转为数组

void toString(String[] s) ---> 将集合转为指定数组s,并可通过Arrays.toString(s)获取数组s中的元素

1)指定类型的数组定义的长度:

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

b.当指定类型的数组长度大于了集合的size,就不会创建数组,而是使用传递进来的数组,并且多出的元素的值为null

2)为何将集合转为数组:为了限定对集合中元素的操作,如增删,因为想对创建的集合不做增删方面的操作。


示例:

	......
	public static void sop(Object obj)
	{
		System.out.println(obj);
	}
	......
	int[] arr = {5,8,6};
	sop("toString : int[]转为集合:" + Arrays.toString(arr));
	
	String[] sarr = {"ac","eg","nse","gui"};
	List<String> list = Arrays.asList(sarr);
	sop("asList--String对象数组转集合:" + list);

	List<int[]> li = Arrays.asList(arr);
	sop("asList--int[]转集合:" + li);
	Integer[] iarr = {5,8,6};
	List<Integer> lis = Arrays.asList(iarr);
	sop("asList--Integer[]转集合:" + lis);
	......

集合转数组:

		ArrayList<String> as = new ArrayList<String>();
		as.add("01");
		as.add("02");
		as.add("03");
		sop("原集合" + as);
		String[] s = new String[as.size()];
		as.toArray(s);
		sop("新数组" + Arrays.toString(s));

第二节 小知识点

一、增强for循环

1、格式:

for(数据类型 变量名 : 被遍历的集合(Collection)或数组){执行语句}

2、说明:

1)对集合进行遍历,只能获取集合的元素,但是不能对集合进行操作。

2)迭代器除了遍历外,还可进行remove集合中元素的操作,如果使用ListIterator,还可在遍历过程中,对集合进行增删改查的操作。

3、传统for循环和增强for循环区别:

增强for循环有局限性。必须有被遍历的目标;而传统for循环有索引。所以建议在遍历数组时,使用传统for循环。

示例:

import java.util.*;
class ForEachDemo
{
	//打印方法
	public static void sop(Object obj)
	{
		System.out.println(obj);
	}

	//测试
	public static void main(String[] args) 
	{
		//创建集合
		ArrayList<String> as = new ArrayList<String>();
		as.add("01-a");
		as.add("02-b");
		as.add("03-c");
		System.out.println("原集合" + as);
		//增强for循环取出元素
		for (String s : as)
		{
			System.out.println(s);
		}
		System.out.println("-------------------------");
		//创建HashMap集合
		HashMap<Integer,String> hm = new HashMap<Integer,String>();
		hm.put(1,"a");
		hm.put(2,"b");
		hm.put(3,"c");
		hm.put(4,"d");
		System.out.println("hm原集合:" + hm);
		//增强for循环的两种方式测试
		//keySet方法
		sop("keySet方法:|--");
		for(Integer i : hm.keySet())
		{
			sop(i + ":-" + hm.get(i));			
		}
		//entrySet方法
		sop("entrySet方法--");
		for(Map.Entry<Integer,String> me : hm.entrySet())
		{
			sop(me.getKey() + "-->" + me.getValue());
		}
	}
}

二、可变参数:

如果在参数列表中传入多个参数,个数不确定,每次都要复写该方法,可变参数的出现就可以省去复写的麻烦,而直接对数组进行操作

注意:可变参数一定要定义在参数列表的后面。

示例:

	......
	//1.5版本前写法
	public static void show(int a,int b)
	{
		System.out.println(a + " :" + b);
	}
	//1.5新特性,可加入更多的值
	public static void show(int... arr)
	{
		System.out.println(arr.length);//结果为数组arr的长度
		System.out.println(arr);//arr的地址值
	}
	public static void print(String... s)
	{
		//遍历字符串数组s
		for(String str : s)
		{
			System.out.print(str);
		}
		System.out.println();
	}
	
	......

三、静态导入:

静态导入,是将类中的所有静态成员导入进来,但需要注意的是,当导入的两个类中有同名成员时,需要在成员前加上相应的类名。

当类名重名时,需要制定具体的包名;当方法名重名时,制定具体所属的对象或类。

1、import static java.util.Arrays.*; ---> 写入的是Arrays类中的所有静态成员。

2、import static java.lang.System.*; ---> 导入了System类中的所有静态成员

import java.util.*;
import static java.util.Arrays.*;//导入的是Arrays类中的所有静态成员
import static java.lang.System.*;//导入的是System类中的所有静态成员
class Demo
{
	public static void main(String [] args)
	{
		int[] arr = {2,7,6,3};
		sort(arr);
		out.println(Arrays.toString(arr));//此处不可省略Arrays,原因见下

	}
}



分享到:
评论

相关推荐

    Windows Sysinternals Suite Build 20071026 - 微软免费工具程序集

    &lt;br&gt;- AccessChk&lt;br&gt;- AccessEnum&lt;br&gt;- AdExplorer&lt;br&gt;- AdRestore&lt;br&gt;- Autologon&lt;br&gt;- Autoruns&lt;br&gt;- BgInfo&lt;br&gt;- CacheSet&lt;br&gt;- ClockRes&lt;br&gt;- Contig&lt;br&gt;- Ctrl2Cap&lt;br&gt;- DebugView&lt;br&gt;- DiskExt&lt;br&gt;- Diskmon...

    java反编译工具jad 1.5.8g(可以反编译jdk1.5,1.6)

    &lt;br&gt;jad -sjava -r -8 -o **\*.class &lt;br&gt;&lt;br&gt;---------------&lt;br&gt;This is README file for Jad - the fast Java Decompiler.&lt;br&gt;Jad home page: http://www.kpdus.com/jad.html&lt;br&gt;Copyright 2001 Pavel Kouznetsov...

    netcat

    &lt;br&gt;-h 帮助信息 &lt;br&gt;-i secs 延时的间隔 &lt;br&gt;-l 监听模式,用于入站连接 &lt;br&gt;-L 连接关闭后,仍然继续监听 &lt;br&gt;-n 指定数字的IP地址,不能用hostname &lt;br&gt;-o file 记录16进制的传输 &lt;br&gt;-p port 本地端口号 &lt;br&gt;-r ...

    Advanced WarCraft 3 Configurator

    &lt;br&gt;---WAR3修改工具;&lt;br&gt;---OpenGL模式(在一些电脑上增加别的模式);&lt;br&gt;---图象比例调整;&lt;br&gt;---皮肤颜色的选择;&lt;br&gt;---多种语言选择;&lt;br&gt;---提示优化技巧和帮助;&lt;br&gt;---包含PING探测功能的网关编辑器&lt;br&gt;-...

    Delphi7.完美经典.part1

    &lt;br&gt;&lt;br&gt;第4章 Delphi Object Pascal的初步印象 &lt;br&gt;&lt;br&gt;4-1 面向对象程序概论 &lt;br&gt;4-1-1 类 &lt;br&gt;4-1-2 对象 &lt;br&gt;4-1-3 继承 &lt;br&gt;4-1-4 封装 &lt;br&gt;4-1-5 信息 &lt;br&gt;4-2 Delphi项目结构及窗体的建立 &lt;br&gt;4-2-1 GUI模式...

    ASP与SQL网页数据库程序设计

    2 Request对象 261&lt;br&gt;9-2-1 ClientCertificate变量 262&lt;br&gt;9-2-2 Cookies集合 262&lt;br&gt;9-2-3 Form集合 264&lt;br&gt;9-2-4 QueryString变量 266&lt;br&gt;9-2-5 ServerVariables集合 270&lt;br&gt;9-3 Session对象的基础与应用 ...

    PDF编辑器

    许多人&lt;br&gt;都希望能找到一个象编辑其它类型的文档的编辑器,事实上在&lt;br&gt; Foxit PDF Editor 出现之前,根本没有这样的工具。每一个&lt;br&gt;PDF 文件都包含很多页面,每一页包含各种可视对象,如文本&lt;br&gt;对象、图形对象和...

    《嵌入式系统开发圣经(第二版)》电子版

    mode:i-appli 326&lt;br&gt;4-7 Java Chip让Java飞起来 337&lt;br&gt;4-7-1 Java Chip的诞生 338&lt;br&gt;4-7-2 各家的JavaChip 339&lt;br&gt;4-7-3 小结 343&lt;br&gt;4-8 总结 344&lt;br&gt;第5章 Smart Handheld Device软件系统设计 345&lt;br&gt;5-1 前言...

    gb28181规约ipc模拟器(验证过)

    备份俩个gb28181测试工具(&lt;Conf&gt; &lt;LocalInfo&gt; &lt;!--本地IP地址--&gt; &lt;Addr&gt;10.11.15.9&lt;/Addr&gt; &lt;!--本地端口--&gt; &lt;Port&gt;6060&lt;/Port&gt; &lt;!--设备ID--&gt; &lt;DeviceID&gt;34020000001110000001&lt;/DeviceID&gt; &lt;!--通道...

    List<Map>转化为List工具类

    一般使用springjdbc、hibernate的sql查询,库获取到的数据都是List&lt;Map&lt;String, Object&gt;&gt;结果集,如果我们要转化为JavaBean,则需要做一系列的...此工程中就是解决List&lt;Map&lt;String, Object&gt;&gt;转化为JavaBean工具类实现

    iDesktopCalendar V1.1.0(我的桌面日历)

    iDesktopCalendar(我的桌面日历)&lt;br&gt;&lt;br&gt;运行环境:WIN2000/XP/2003/VISTA&lt;br&gt;软件类别:桌面工具&lt;br&gt;授权形式:免费&lt;br&gt;软件作者:蓝剑&lt;br&gt;技术支持:pdc2008@hotmail.com&lt;br&gt;&lt;br&gt;【软件介绍】&lt;br&gt;我的桌面日历...

    UML教程

    04class-object-package.ppt&lt;br&gt;4e-05状态-活动-构件-配置图.ppt&lt;br&gt;4e-06Web建模.ppt&lt;br&gt;4e-07Rose开发工具.ppt&lt;br&gt;4e-08UML与设计模式.ppt&lt;br&gt;4e-09UML常见问题分析.ppt&lt;br&gt;4e-10面向对象实现技术.ppt&lt;br&gt;4e-11RUP...

    Glass Fish帮助手册

    &lt;br&gt;&lt;br&gt;例如asadmin start-domain 命令:&lt;br&gt;Name: start-domain – starts a domain&lt;br&gt;Synopsis: start-domain [--domaindir domain-dir]&lt;br&gt; --user admin_user --passwordfile file_name&lt;br&gt; [--terse=...

    cas 配置client 1.0 &2.0 及proxy DEMO 说明

    &lt;description&gt;cas1 demo&lt;/description&gt; &lt;!-- cas filter --&gt; &lt;filter&gt; &lt;filter-name&gt;CAS Filter&lt;/filter-name&gt; &lt;filter-class&gt; edu.yale.its.tp.cas.client.filter.CASFilter &lt;/filter-class&gt; &lt;!-- ...

    实时数仓flink ClickHouse工具类

    封装 ClickHouse 工具类和方法 相关依赖 &lt;dependency&gt; &lt;groupId&gt;ru.yandex.clickhouse&lt;/groupId&gt; &lt;artifactId&gt;clickhouse-jdbc&lt;/artifactId&gt; &lt;version&gt;0.3.0&lt;/version&gt; &lt;exclusions&gt; &lt;exclusion&gt; &lt;groupId&gt;...

    网页编码转换

    &lt;br&gt;程序功能:将 GB、BIG5、UTF-8 文件相互转换&lt;br&gt;--------------------------------------&lt;br&gt;字符编码转换工具 ;&lt;br&gt;功能:功能齐全,可以说都能转换,万能的&lt;br&gt;-----------------------------------------&lt;br&gt;...

    struts2.0官方项目之四(showcase)

    &lt;br&gt; ------------------------------------------------&lt;br&gt; 实例说明:&lt;br&gt;&lt;br&gt; 将&lt;br&gt;&lt;br&gt; “struts2-mailreader-2.0.9.war”&lt;br&gt;&lt;br&gt; 改为&lt;br&gt;&lt;br&gt; “struts2-mailreader-2.0.9.rar”&lt;br&gt;&lt;br&gt; 使用解压工具解压-...

    EditMinus 0.4 build 20080112

    i ++) &lt;br&gt;{ &lt;br&gt;&lt;br&gt;} &lt;br&gt;第一个TAB停留在unsigned int上,第二个TAB停留在i上,如果修改i为idx, &lt;br&gt;那么接下去的几个i都被统一自动更改为idx &lt;br&gt;目前主要把C/C++,Java和Python的bundle引入了。 &lt;br&gt;- 添加...

Global site tag (gtag.js) - Google Analytics