List集合
集合类方便操作,增删查找容易。
集合的超级接口collection:
1.List:
1.ArrayList:是存在一个数组(Object[]),添加,删除元素很慢,查找很快,元素在内存中是有序的。
2.LinkedList:添加元素比较快,删除,查找比较慢,元素在内存中是无序的。
ArrayList:维护的是一个Object[],默认容量是10,如果默认不够就增加为原来的1.5倍。
ArrayList:特有的方法
ensureCapacity(int minCapacity):手动增加容量。
trimToSize():调整集合的容量刚好符合元素的个数。
2.set:也是一个接口:继承Collection
特点:无序是无序的,不能重复的。
2.HashSet:用哈希表来存值。
原理:如果用HashSet存放对象,首先会调用对象的hashCode方法获取到哈希值,通过哈希表值做移位运算,计算出元素在哈希表中的位置。
情况一:如果算出的位置没有任何元素,可以直接将对象存放在该位置。
情况二:如果算出的位置存在元素,这个时候会调用将要存入的元素的equals方法和已经存在的元素作对比,如果equals返回的true那么就表示是重复的元素,如果equals返回的是false直接将元素一样保存在该位置。
3.TreeSet:里面存放的元素会根据自然顺序进行排序。
1.如果添加的元素存在自然排序的特性,那么存入的元素就会通过自然排序
2.如果添加的元素,不具备自然排序的特性,那么这个时候定义的类必须要实现Comparable接口。将元素的比较规则定义到ComparTo方法中去。
ComparTo的比较规则:返回一个0或者负数或者整数,分别表示相等,大于,小于。
3.自定义比较器:既没有自然特性,又没有实现ComparTo,这个时候就需要在写TreeSet对象时传一个比较器。
比较器的定义方式:
自定义一个类实现:Compartor接口
通过实现Compartor中Compar(Object o1,Object o2)来指定元素的比较规则。
4.TreeSet:底层是使用二叉树来存放数据的。
list:元素是有序的,可以重复。
list 中特有的方法:
1.添加元素:
add(String str);向滚动列表的末尾添加指定的项。
add(String str,int index);向滚动列表中索引指示的位置添加指定的项。
add(int index,Collection e);向滚动列表中索引指示的位置添加指定的集合。
2.获取元素:
get(int index);获取指定索引位置的元素。
subList(int fromIndex,int toIndex);截取指定范围的元素。
3.查找元素:
indexOf(Object o);如果有就返回第一次出现的位置。如果没有就返回-1。
lastIndexOf(Object o);查找集合的最后一个元素。
4.删除元素:
remove(int index);删除指定位置的元素。
5.更新集合:
set(int index,Object o);替换指定位置的值。
6.list集合中的迭代器:listIterator()
创建一个迭代器
Iterator it = list.iterator();
7.用三种方法遍历集合list:
第一种方法(toArray)
list list = new ArrayList();
list.add(12);
list.add(1);
list.add(2);
//把集合变成数组的形式进行遍历
Object[] obj = list.toArray();
for (int i = 0; i < obj.length; i++){
System.out.println(obj[i]);
}
第二种方法(get())
for(int i = 0; i < list.size(); i++){
System.out.println(list.get(i));
}
第三种方法(iterator):
Iterator it = list.iterator();
while(it.hasNext()){
System.out.println(it.next());
}
迭代器:
1.迭代器用来操作集合中的元素,增删,获取集合中的对象。
Iterator:迭代器的超级接口,所有的迭代器的接口都是继承Iterator。
2.迭代器中常用的方法:
hasNext();判断当前指针指向的位置是否存在元素。
next();获取当前指针指向的元素,这个方法调用一次指针就会下移一次。
remove();删除最后一次出现的对象。也就是指针所指位置的元素。
List 集合中特有的方法 都是通过下标来操作的.
listItreaor : 继承 Iteraor
listItreaor : 特有的方法:
hasPrevious();获取当前指针指向的上一个元素
previous();获取上一个元素
previousIndex();获取上一个元素的索引位置
add(String str);
set(String str);
List集合的更多相关文章
- java基础集合经典训练题
第一题:要求产生10个随机的字符串,每一个字符串互相不重复,每一个字符串中组成的字符(a-zA-Z0-9)也不相同,每个字符串长度为10; 分析:*1.看到这个题目,或许你脑海中会想到很多方法,比如判 ...
- .Net多线程编程—并发集合
并发集合 1 为什么使用并发集合? 原因主要有以下几点: System.Collections和System.Collections.Generic名称空间中所提供的经典列表.集合和数组都不是线程安全 ...
- 一起学 Java(三) 集合框架、数据结构、泛型
一.Java 集合框架 集合框架是一个用来代表和操纵集合的统一架构.所有的集合框架都包含如下内容: 接口:是代表集合的抽象数据类型.接口允许集合独立操纵其代表的细节.在面向对象的语言,接口通常形成一个 ...
- 编写高质量代码:改善Java程序的151个建议(第5章:数组和集合___建议75~78)
建议75:集合中的元素必须做到compareTo和equals同步 实现了Comparable接口的元素就可以排序,compareTo方法是Comparable接口要求必须实现的,它与equals方法 ...
- java基础_集合List与Set接口
List接口继承了Collection的方法 当然也有自己特有的方法向指定位置添加元素 add(索引,添加的元素); 移除指定索引的元素 remove(索引) 修改指定索引的元素 set ...
- Java基础Collection集合
1.Collection是所有集合的父类,在JDK1.5之后又加入了Iterable超级类(可以不用了解) 2.学习集合从Collection开始,所有集合都继承了他的方法 集合结构如图:
- 轻量级“集合”迭代器-Generator
Generator是PHP 5.5加入的新语言特性.但是,它似乎并没有被很多PHP开发者广泛采用.因此,在我们了解PHP 7对Generator的改进之前,我们先通过一个简单却显而易见的例子来了解下G ...
- Asp.net MVC 传递数据 从前台到后台,包括单个对象,多个对象,集合
今天为大家分享下 Asp.net MVC 将数据从前台传递到后台的几种方式. 环境:VS2013,MVC5.0框架 1.基本数据类型 我们常见有传递 int, string, bool, double ...
- 这些.NET开源项目你知道吗?.NET平台开源文档与报表处理组件集合(三)
在前2篇文章这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧 和这些.NET开源项目你知道吗?让.NET开源来得更加猛烈些吧!(第二辑)中,大伙热情高涨.再次拿出自己的私货,在.NET平台 ...
- python 数据类型 --- 集合
1. 注意列表和集合的区别 set 列表表现形式: list_1 = [1,3,4]; 集合表现形式:set_1= set() list_1 = [1,2,3,4,23,4,2] print(lis ...
随机推荐
- 安装Hadoop系列 — 安装Hadoop
安装步骤如下: 1)下载hadoop:hadoop-1.0.3 http://archive.apache.org/dist/hadoop/core/hadoop-1.0.3/ 2)解压文 ...
- 中断服务程序不用interrupt关键字也可实现中断,该关键字是否必须?
2013-06-20 11:13:35 中断服务程序不用interrupt关键字也可实现中断,该关键字是否必须? 使用tools->pin connect,将INT5与pin.txt关联,模拟外 ...
- WinAPI——Windows 消息
消息 值 注释 WM_NULL $0000 WM_CREATE $0001 WM_DESTROY $0002 WM_MOVE $0003 WM_SIZE $0005 WM_AC ...
- Oracle中Blob和Clob类型的区别与操作
Oracle中Blob和Clob类型 1.Oracle中Blob和Clob类型的区别 BLOB和CLOB都是大字段类型,BLOB是按二进制来存储的,而CLOB是可以直接存储文字的.其实两个是可以互换的 ...
- IL指令集(转)
名称 说明 Add 将两个值相加并将结果推送到计算堆栈上. Add.Ovf 将两个整数相加,执行溢出检查,并且将结果推送到计算堆栈上. Add.Ovf.Un 将两个无符号整数值相加,执行溢出检查,并且 ...
- 设计模式 - command
将请求封装为对象,从而可以使用不同的请求对客户进行参数化,该模式的关键在于对不同请求的封装.简单的说,也就是在请求发出者和客户间通过command对象进行解耦,从而使得请求者可以通过实例化不同的com ...
- 初探数位dp
数位dp有着很明显的特点,一般来说是给定区间[l,r]求满足某种条件区间中的数有多少个 朴素解法一般是O(n)的而n往往很大(10^8起步) 这时候我们就要想办法优化,于是就有了数位dp 数位有两个基 ...
- HAOI2006受欢迎的牛
求出强联通分量之后判断出度为0的点有几个,有1个就输出这个分量的点的数目,否则输出0: var i,j,n,m,x,y,ans1,ans2,t,cnt,top:longint; head,next,g ...
- vijos1603迷宫
这题的构思太巧妙了: 经典题目8 给定一个有向图,问从A点恰好走k步(允许重复经过边)到达B点的方案数mod p的值 把给定的图转为邻接矩阵,即A(i,j)=1当且仅当存在一条边i->j. ...
- I.MX6 U-boot Kernel backlight setting
/********************************************************************* * I.MX6 U-boot Kernel backlig ...