Java中的集合

一:三类集合
A . List:接口

1.特点:值不唯一,有序[插入的顺序]

2.实现

1、ArrayList

特点:一组有序[值插入的顺序]并且可以重复的集合

储存方式:在堆里面开辟了一段连续的空间

语法

//不限定数据类型
ArrayList list=new ArrayList();
//限定数据类型
ArrayList<数据类型> list=new ArrayList<数据类型>();
//父类指向子类对象
List list=new ArrayList();

方法

方法类型意思
add()添加数据
get(下标);取指定下标的值
size()长度
remove(下标)删除指定下标的值
remove(值)删除指定值
contains()判断是否存在此元素
clear()删除所有数据

遍历

1 .for

for (int i = 0; i < 对象名.size(); i++) { 
	System.out.println(对象名.get(i));
}

2 .foreach

for (数据类型 变量名 : 对象名) {
	System.out.println(变量名);
}

3 .Iterator

步骤

1、先将list对象转换为Iterator对象
2、通过Iterator对象的hasNext方法判断是否有一个值
3 、通过Iterator对象的next方法取值

代码

Iterator<数据类型> it = list.iterator();
while(it.hasNext()){
    System.out.println(it.Next());
}
2、LinkedList

特点:采用链式存储规则

作用:适用于集合数据频繁的修改;

方法

方法意思
addFirst()在列表的首添加数据
addLast()在列表的尾添加数据
getFirst()返回列表的第一个元素
getLast()返回列表的最后一个元素
removeFirst()删除并返回列表的第一个元素
removeLast()删除并返回列表的最后一个元素

【注意:它的语法,其他方法,遍历与ArrayList一样】

B .Set:接口

特点:无序【不按照插入的顺序排序】,并且不重复

操作:类似List

实现:

  1. HashSet:存储方式类似数组,插入数据的是没有任何顺序
  2. TreeSet:以树形结构图存储,实现了SortedSet接口,有排序功能,默认从小到大
C .Map:接口

储存方式:一组成对键-值

实现

1 .HashMap:线程不安全,速度快

2 .Hashtable:操作类似HashMap,线程安全

3 .ConcurrentMap:操作类似HashMap,线程安全,优点:针对线程安全部分代码做了优化

4 .TreeMap:对key进行排序,key不能以null

语法

//不限定数据类型
HashMap map=new HashMap();
//限定数据类型
HashMap<key数据类型,value的数据类型> map=new HashMap<key数据类型,value的数据类型();
//父类指向子类对象
Map map=new HashMap();

方法

方法意思
put(key,value)添加数据
get(key)返回数据
remove(key)删除指定下标的元素
size()元素个数
Set keySet返回键的集合
Collection values()返回值的集合
containsKey()判断键是否存在
二:类

Collection:(是接口)
作用:是List和Set的父类
Collections
作用:是操作集合的工具类
【操作数组的工具类:Arrays;方法:Arrays.sort(数组)—》排序】
Iterator:
作用:专门用于迭代【遍历】集合

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值