T-4-java核心API-集合类
- 用于存储类型一致的一组对象的数据结构。
- 类似于数组,但是集合提供了操作算法:集合=数据存储+操作算法。集合的用途极其广泛,如歌曲列表,联系人列表对话记录等。
- 集合比数组多了操作算法,便于提高编程效率。
- collection是一个接口,定义了集合相关的操作方法,其有两个子接口:List(可重复)与Set(不可重复),元素是否重复,取决于元素的equals()比较的结果。
- collection方法,集合在判断元素是否被包含在集合中,是根据元素的equals()方法进行比较的结果(o==null?e==null:o.equals(e))。
- addAll方法,该方法需要我们传入一个集合,并将该集合中所有元素添加到当前集合中。
- containsAll方法,该方法用于判断当前集合是否包含给定集合中的所有元素。
- Iterator迭代器,逐一遍历或迭代处理集合中的元素。
- 集合提供的算法不能满足业务需要时,使用迭代实现。
- Collection定义了iterator方法,用于创建Iterator接口实例,子类实现了这个方法。
- Iterator接口一般都是用“内部类”实现的,用i.getClass().getName()可查看。
- Iterator是给while()语句定制的。
- 迭代期间,不能使用集合方法添加或删除元素,迭代器提供了安全删除方法.remove()。在使用迭代器遍历集合时,不能通过集合的remove方法来删除集合元素,否则会抛出异常。我们可以通过迭代器自身提供的remove()方法来删除,通过next()迭代出元素,这里需要注意的是,在调用remove方法前必须通过迭代器的next()方法迭代过元素,那么删除的就是这个元素,并且不能再次调用remove方法,除非再次调用next()后方可再次调用。
- 语法:for(元素类型 e : 集合或数组){循环体;}
- 在编译过程中,编译器将新循环转换为迭代器模式,所以新循环本质上是迭代器。
- 只能用于遍历,不能用于更改或删除。
- Java SE 5.0引入的特性,泛型的本质是参数化类型,在类、接口和方法的定义过程中,所操作的数据类型被传入的参数指定。
- List继承了Collection,扩展了与位置有关的操作方法,实现类有两个:ArrayList和LinkedList,外观一致都是List。
- 任何时候,需要使用集合,不确定类的时候,首先选择ArrayList。
- ArrayList和LinkedList分别用动态数组和链表的方式实现了List接口。
- 可以认为ArrayList和LinkedList的方法在逻辑上完全一样,只是性能上有一定差别。ArrayLIst更适合于随机访问,而LinkedList更适合于插入与删除。
- ArrayList可以通过下标迅速索引到对应的元素,但在删除或插入时移动较多元素,LinkedList在删除或插入时只需要改变链接“指针”即可实现。
- 如果列表List能放入指定的数组,则返回放入此列表的元素的数组,否则,将根据指定数组运行时的类型和List的大小分配一个新的数组。
- 如果指定的数组足够大,并且剩余空间,那么会将数组中紧跟在集合末尾的元素设为null。
- void add(int index,E element);将给定的元素插入到指定位置,原位置及后续元素都顺序向后移动。
- E remove(int index);删除给定位置的元素,并将被删除的元素返回。
- subList方法用于获取子List。需要注意的是,subList获取的List与原List占有相同的存储空间,对子List的操作会影响原List。
- 返回一个受指定数组支持的固定大小的列表(对返回列表的更改会“直写”到数组)。
- 返回的List的集合元素类型由传入的数组的元素类型决定。
- 返回的集合我们不能对其增删元素,否则会抛出异常。
- 对集合元素进行修改,会影响到数组对应的元素。
- 利用Collection.sort(List),可以对给定的集合元素进行自然排序。
- Comparable接口。使用Collections的sort排序的集合元素,都必须是Comparable接口的实现类,该接口表示其子类都是可比较的,因为实现该接口必须重写抽象方法CompateTo(T t);
- CompareTo方法。用于使当前对象与给定对象进行比较。若当前对象大于给定对象,那么返回值应为>0的整数;若小于给定对象,那么返回值为<0的整数;若两个对象相等,则应返回0.
- 一旦java类实现了Comparable接口,其比较逻辑就已经确定;如果希望在排序的操作中临时指定比较规则,可以采用Comparator接口回调的方式。
- Comparator接口要求实现类必须重写其定义的方法:Compare(T o1,T o2),返回值是>0 <0 =0。
- 利用方法Collections.sort(list, 比较器),就可以进行任意规则的排序。
- Queue,一种特殊的线性表,只能从线性表的一端添加(offer)元素,从另一端取出(poll)元素,遵循先进先出(FIFO)的原则。
- LinkedList实现了Queue接口。
- Deque是Queue的子接口,定义了所谓“双端队列”,即从队列的两端分别可以入队(offer)或出队(poll),Linkedlist实现了该接口。
- 如果将Deque限制为只能从一端入队和出队,则可实现“栈”(stack)的数据结构,对于栈而言,入栈称之为push,出栈称之为pop,栈遵循先进后出(FILO)的原则。
- Map的方法:put/get/containsKey/keySet/entrySet/clear/size/isEmpty/containsValue/remove
- 作为Map中的key,一定要很好地实现equals和hashCode,必须成对实现(就是当两个对象equals相等的时候,一定具有相同的hashCode。
- 无论get/put,都是先利用hashCode计算桶的位置,再利用equals比较元素的位置。
- 如果hashCode的值不稳定,或没有成对重写,会造成HasMap的工作故障。
- Map根据key查找value,key是不可重复的,value可以重复。
- Map的常见实现类是散列表HashMap,是散列算法实现的,有极其优秀的查询性能,相对于顺序查询性能优秀。
- 散列表插入过程(put):获得key的hashCode(),利用散列算法映射到散列表数组中“散列桶”的位置,遍历散列桶,使用key.equals()方法逐一比较key,确定位置,添加(替换)数组。
- 散列表查找过程(get):根据key查找value(数据),获得key的hashCode(),利用散列算法映射到散列表数组中散列桶的位置,使用key.equals()方法逐一比较key确定位置,获取这个位置的数据(value),如果没有数据,就返回null。
- 散列表的默认加载因子是75%
- 75%是散列表中所有元素数量与散列表容量的最大比值。
- 一旦实际的比值超过加载因子,散列表或扩容,并重新散列。
- 减少散列表的扩容次数,将有助于提高散列表的性能。
- LinkedHashMap能够利用链表保持元素的添加顺序,HashMap是散列的顺序不能保持元素顺序。
T-4-java核心API-集合类的更多相关文章
- Java核心API需要掌握的程度
		分类: java技术2009-08-29 01:03 213人阅读 评论(0) 收藏 举报 javaapiswingxmlio Java的核心API是非常庞大的,这给开发者来说带来了很大的方便,经常人 ... 
- 2018.6.19  Java核心API与高级编程实践复习总结
		Java 核心编程API与高级编程实践 第一章 异常 1.1 异常概述 在程序运行中,经常会出现一些意外情况,这些意外会导致程序出错或者崩溃而影响程序的正常执行,在java语言中,将这些程序意外称为异 ... 
- java核心API学习
		1:java.lang (Object.String.StringBuffer.Thread.System.ClassLoader.Class.Runtime.包装类等) 
- java核心API
		---恢复内容开始--- Javase01 day01 关于String: String是不可变对象,java.lang.String使用了final修饰,不能被继承: 字符串一旦创建永远无法改变,但 ... 
- 【Java核心】ClassLoader原理及其使用
		又把博客的皮肤换了换,看着更加简洁舒心一些.前段的知识只是略懂,拿过来就能用,只是自己的审美和设计水平有限,实在难以弄出自己特别满意的东西,也算是小小的遗憾吧!言归正传,由于最近涉及到Java核心的东 ... 
- java多线程核心api以及相关概念(一)
		这篇博客总结了对线程核心api以及相关概念的学习,黑体字可以理解为重点,其他的都是我对它的理解 个人认为这些是学习java多线程的基础,不理解熟悉这些,后面的也不可能学好滴 目录 1.什么是线程以及优 ... 
- 深入Java核心 Java中多态的实现机制(1)
		在疯狂java中,多态是这样解释的: 多态:相同类型的变量,调用同一个方法时,呈现出多中不同的行为特征, 这就是多态. 加上下面的解释:(多态四小类:强制的,重载的,参数的和包含的) 同时, 还用人这 ... 
- Java Attach API
		catalog . instrucment与Attach API . BTrace: VM Attach的两种方式 . Sun JVM Attach API 1. instrucment与Attach ... 
- Java核心_内省
		Java核心_内省 查看java的api,发现有一个包java.bean咦,这个包是干什么的呢,原来,它是用来操作JavaBean对象的! 一.内省操作①JavaBean:一种特殊的Java类无参构造 ... 
- Java核心 --- 注解
		Java核心——注解 注解是jdk5以后的新特性,Spring和Hibernate等框架提供了注解的配置方式使用, 本文参考了浪曦风中叶的注解讲解,主要讲解jdk内置注解的用法,注解的声明和定义,以及 ... 
随机推荐
- 深度学习实践-物体检测-faster-RCNN(原理和部分代码说明)  1.tf.image.resize_and_crop(根据比例取出特征层,进行维度变化) 2.tf.slice(数据切片) 3.x.argsort()(对数据进行排列,返回索引值) 4.np.empty(生成空矩阵) 5.np.meshgrid(生成二维数据) 6.np.where(符合条件的索引) 7.tf.gather取值
			1. tf.image.resize_and_crop(net, bbox, 256, [14, 14], name) # 根据bbox的y1,x1,y2,x2获得net中的位置,将其转换为14*1 ... 
- 微信小程序海报生成功能
			如果是H5页面的话给大家推荐一款不错的插件html2canvas,这个插件可以将html元素转为canvas并一键生成png图片,但是本文的重点是在小程序上如何实现生成图片的功能.因为小程序没有DOM ... 
- docker镜像无法下载或者下载缓慢
			解决docker镜像无法下载的问题 2015年10月02日 16:01:05 阅读数:20776 克服跨洋网络延迟,使用Docker Hub Mirror加速Docker官方镜像下载 http://c ... 
- mysql学习一 常用语句
			操作系统为windows 1 启动关闭mysql服务 //windows mysqld --console //开启mysql服务 mysqladmin -uroot shutdown //关闭my ... 
- 吴裕雄 python 机器学习——Lasso回归
			import numpy as np import matplotlib.pyplot as plt from sklearn import datasets, linear_model from s ... 
- JS数据类型之String类型
			转换为字符串 var num = 10 num.toString(); //"10" 转换为字符串-参数表示几进制的字符串 var stringValue = "hell ... 
- C# 消息队列 RabbitMQ
			1.引言 RabbitMQ——Rabbit Message Queue的简写,但不能仅仅理解其为消息队列,消息代理更合适. RabbitMQ 是一个由 Erlang 语言开发的AMQP(高级消息队列协 ... 
- 今天遇到一个怪异的问题,maven生成项目war包中有一个Jar包不是我指定的版本,运行时会找不到符号,o(╥﹏╥)o
			我要求的jar包: 这是我parent项目中pom文件的依赖管理 这是我要生成war包那个工程最后依赖的jar包,这个时候它们的版本号还是一致的 最后项目生成的: 下图是Dmaven.test.ski ... 
- aop原理及理解
			概念 Aspect Oriented Programming,面向切面编程,实际上它是一个规范.一种设计思路,总之是抽象的. 先上图 使用目的 从项目结构上来说 对业务逻辑的各个部分进行隔离,降低业务 ... 
- Jboss项目部署出现java.lang.UnsupportedClassVersionError 问题的解决方法
			出现java.lang.UnsupportedClassVersionError 错误的原因,是因为我们使用高版本的JDK编译的Java class文件试图在较低版本的JVM上运行,所报的错误. 解决 ... 
