java中的集合
集合比数组的优势:
1.集合可以存任意类型的变量,长度是可变的
2.数组只能存同一类型的变量,长度是固定的
3.集合中只能存对象
List集合 : 接口 提供公有的方法
特有的方法:
1.List中特有的方法都是通过下标来操作元素的
查找:
add(int index,Object 0)添加元素到指定的位置
get(int index),获取集合中指定位置的元素
Set(int index,object o),用来修饰集合中指定位置的元素的值
迭代器:
作用:操作集合中的元素,可以(增 , 删 ,改 ,查)
根迭代器:Iterator 接口 集中获取迭代器 : 通过集合中的方法获取迭代器
collection 集合中获取迭代器:Iterator();
迭代器中的方法:
hasNext();//判断当前指针指向的位置是否有元素
next(); //获取当前指针指向的元素,并且指针下移一位
remove(); //移除最后操作是指针指向的元素
ListIterator: 中的特有方法:
hasPrpvious();判断当前指针指向的上一个位置是否存在元素
provious(); 获取上一个元素
proviousIndex();获取上一个元素所在的位置
add();在当前指针指向的位置添加一个元素
set();修改当前指针指向的元素
1.add和set不能同事使用
2.如果使用迭代器操作元素,那么就不要用集合来操作元素
ArratList : 底层是维护一个Object[] 数组,默认的容量是10,如果容量不够,增加为原来的1.5倍,
优点:查找块 ,增删慢
trimToSize()。调整集合的容量和数据保持一致
ensureCapacity(int minCapacity)自定义容量
LinkedList :连接列表实现, 特点:添加元素比较快。查找慢
LinkedList特有的方法:
方法介绍:
addFirst(E e)
addLast()
getLast()
removeFirst()
removeLast()
如果集合中没有元素,获取或者删除元素抛:NoSuchElementException:没有找到元素的异常
数据结构:
第一个方法 : List.push(“***”) //往集合的堆栈中推入一个值
System.out.println("从集合中堆栈中取出值:"+list.pop()); // 狗娃 移除push进去的对象 pop()取栈中最上面的对象
先进先出:
list.offer(“狗娃”);
System.out.printn(list.poll()); // 会将元素从集合中移除
获取逆序的迭代器
descendingIterator()
返回以逆向顺序在此双端队列的元素上进行迭代的迭代器。
eg: Iterator it= list.descendingIterator()
while(it.hasNext){
System.out.println(it); 反着打印出来
}
Vector : 描述的是一个线程安全的ArrayList 使用和ArrayList一样 (只需了解)
vector 和 ArrayList 区别
相同点: 底层都是用object数组来实现的
不同点:
1.ArrarList是线程不同步,操作效率高, ArrayList是在jdk1.2出现的
2.Vector 线程是同步,操作效率低, 是在jdk1.0时候出现的
Set集合:也是一个接口,继承collection接口,元素是无序的,不能用索引值来取值,不能 重复
hashSet 存值得一个原理:
首先会调用对象的hashCode方法获取hashCode值,通过移位等运算获取一个位置
情况1:如果位置上是没有元素,直接将元素存放在该位置上
情况2:如果位置上已经有了元素,用对象的equals方法和位置上已经存在的对象比较,如果equals返回的是true那就代表是重复对象,就不存在,如果返回的是false将对象和原有的对象存在一起
想要遍历Set集合:1.将集合变为数组,2.通过迭代器来遍历(无序:添加的顺序和打印出来的顺序是不一样的、)
Treeset:使用元素的自热顺序对元素进行排序,底层使用二叉树来实现
Treeset使用注意点:
1.往TreeSet添加对象的时候,如果对象有这个自然排序的特性,就按照这个自然排序进行排序
2.往TreeSet添加对象的时候,如过对象本身不具备自然排序的特性,运行的时候回报错,如果需要存储对象,那么的对象的类必须要实现CompareTo接口 把元素的比较的规格定义在CompareTo方法中
3.往TreeSet添加对象的时候,如果对象本身不具备自然排序的特性,并且没有实现Comparable 接口,那么这个时候需要创建一个TreeSet的时候传入一个比较器
比较器的定义方式:
class 类名 inplements Compartor{
}
4.如果类中实现了Comparable 接口,又在创建Treeset时传入一个比较器,这个时候以比较器为标准。
java中的集合的更多相关文章
- Java 中的集合接口——List、Set、Map
Java 中的集合接口——List.Set.Map 什么叫集合:集合就是Java API所提供的一系列类的实例,可以用于动态存放多个对象.这跟我们学过的数组差不多,那为什么我们还要学集合,我们看看数组 ...
- 实现java 中 list集合中有几十万条数据,每100条为一组取出
解决"java 中 list集合中有几十万条数据,每100条为一组取出来如何实现,求代码!!!"的问题. 具体解决方案如下: /** * 实现java 中 list集合中有几十万条 ...
- java中对集合对象list的几种循环访问
java中对集合对象list的几种循环访问的总结如下 1 经典的for循环 public static void main(String[] args) { List<String> li ...
- 菜鸟日记之 java中的集合框架
java中的集合框架图 如图所示:java中的集合分为两种Collection和Map两种接口 可分为Collection是单列集合和Map的双列集合 Collection单列集合:继承了Iterat ...
- C#与java中的集合区别
集合一般的操作 插入: add 删除: remove 查找: contains,remove java中的集合 注意哪些是接口,哪些是实现类 使用集合的时候 1. ...
- java中list集合的内容,如何使用像数据库中group by形式那样排序
java中list集合的内容,如何使用像数据库中group by形式那样排序,比如:有一个 List<JavaBean> 他中包含了一些如下的内容JavaBean:name mone ...
- Java中的集合类型的继承关系图
Java中的集合类型的继承关系图
- (转)java中对集合对象list的几种循环访问总结
Java集合的Stack.Queue.Map的遍历 在集合操作中,常常离不开对集合的遍历,对集合遍历一般来说一个foreach就搞定了,但是,对于Stack.Queue.Map类型的遍历,还是有一 ...
- java中的集合操作类(未完待续)
申明: 实习生的肤浅理解,如发现有错误之处.还望大牛们多多指点 废话 事实上我写java的后台操作,我每次都会遇到一条语句:List<XXXXX> list = new ArrayList ...
- Java中的集合概述
Java中的集合类有两个重要的分支,分别是接口Collection(包括List,Set等)和接口Map. 由于HashSet的内部实现原理使用了HashMap,所以我们先来了解Map集合类. 1.H ...
随机推荐
- C#多线程同步事件及等待句柄AutoResetEvent 和 ManualResetEvent
最近捣鼓了一下多线程的同步问题,发现其实C#关于多线程同步事件处理还是很灵活,这里主要写一下,自己测试的一些代码,涉及到了AutoResetEvent 和 ManualResetEvent,当然还有也 ...
- mtr命令详解
原文地址:http://blog.hexu.org/archives/1050.shtml 一般在windows 来判断网络连通性用ping 和tracert,ping的话可以来判断丢包率,trace ...
- sql 关于查询时 出现的 从数据类型 varchar 转换为 numeric 时出错 的解决方法。
出现这种问题 一般是查询时出现了 varchar 转 numeric 时出了错 或varchar字段运算造成的 解决方法: 让不能转的数不转换就可以了 sql的函数有个isNumeric(参数) 用 ...
- Leetcode 255. Verify Preorder Sequence in Binary Search Tree
验证一个list是不是一个BST的preorder traversal sequence. Given an array of numbers, verify whether it is the co ...
- windows下MySQL 忘记初始密码
一.windows下修改MySQL用户密码的方法: 1.关闭正在运行的MySQL服务:net stop mysql 或 在windows 任务管理器中结束 mysqld.exe 进程 或 在 管 ...
- windows下使用pip安装python的第三方lxml库
lxml是Python语言里和XML以及HTML工作的功能最丰富和最容易使用的库.lxml库的安装和python其他第三方库的安装方法是一样的,只是可能由于一些细节上的失误导致安装失败. 工具 Pyt ...
- python学习笔记-(十三)线程&多线程
为了方便大家理解下面的知识,可以先看一篇文章:http://www.ruanyifeng.com/blog/2013/04/processes_and_threads.html 线程 1.什么是线程? ...
- 【转】精选30个优秀的CSS技术和实例
今天,我为大家收集精选了30个使用纯CSS完成的强大实践的优秀CSS技术和实例,您将在这里发现很多与众不同的技术,比如:图片集.阴影效果.可扩展按钮.菜单等-这些实例都是使用纯CSS和HTML实现的. ...
- 11月6日上午PHP练习《租房子》解析
一.题目要求 二.题目做法 1.建立数据库 2.封装类文件 <?php class DBDA { public $fuwuqi="localhost"; //服务器地址 pu ...
- gzip的使用
经常会有文件过大,给文件的传输和增添了很多的麻烦,早先得知apach有个base64貌似可以用来压缩文件,但是测试没有什么效果,反而增大了文件的大小.今天了解了java自带的gzip包,如获至宝,超级 ...