java中的接口是类吗
301
2022-08-16
Java 超详细图解集合框架的数据结构
目录1、什么是集合框架?2、Collection接口1.通过泛型来指定相应集合中的对象类型2.Collection常见方法使用3、Map 接口Map常见方法使用4、具体的实现类
1、什么是集合框架?
在java中,有一套现成的数据结构,例如顺序表,链表,队列,栈,优先级队列,哈希表等,被封装成了相应的接口/类,供程序员直接使用,只需要创建相关的对象即可以使用,而不需要再实现其内部结构。
集合,就是将多个元素置于一个单元中,用于对这些元素进行增删改查,存储以及管理。例如,一副扑克牌(一组牌的集合)、一个通讯录(一组姓名和电话的映射关系)等等。
下图很重要!!!需要牢记其常用的接口和类!!
因为map接口没有实现Iterable接口,那么要遍历其中的元素该怎么实现呢?
Map
map.put(1,"jack");
map.put(2,"tom");
Set
// 使用迭代器进行遍历 ,增强 for同理
Iterator
while (iterator.hasNext()) {
Map.Entry
System.out.println(entry.getKey() + " " + entry.getValue());
}
上述以HashMap为例,可以调用其 entrySet() 方法,将map里面的每个
基本关系(简易版)
2、Collection接口
一般是用实现了Collection接口的接口或者类来接受具体实现类的对象,因为上图可以看出,Collection接口是一系列接口和类的父接口,其内部实现的方法比较少,所以不能调用一些子类有的常见方法。
1.通过泛型来指定相应集合中的对象类型
注意:这里传入的类型只能是引用类型,如果是基本数据类型,应该用其包装类来指定
Collection
collection1.add("haha");
collection1.add("world");
Collection
collection2.add(1);
collection2.add(2);
//collection2.add("hh");// 这里会报错,不符合传入的指定类型Integer
2.Collection常见方法使用
方法作用void clear()删除集合中的所有元素boolean isEmpty()判断集合是否没有任何元素,俗称空集合boolean remove(Object e)如果元素 e 出现在集合中,删除其中一个boolean add(E e)将元素 e 放入集合中int size()返回集合中的元素个数Object[] toArray()返回一个装有所有集合中元素的数组
注意:在最后一个Object[] toArray() 方法中,返回的是Object[] 类型的数组,底层的做法是:将集合中的元素一个一个拿出来,将其转为 Object 对象,存入要返回的数组中,最终返回一个 Object[] 类型的数组。如果直接将其转换为 String[] 类型的数组,会抛出类型转换异常。
因为这里不能保证数组中的每个元素都转成了String,而只是将其整体强转为了String[] 类型的数组,所以如果非要转,需要先遍历返回的结果,将其一个一个转为String类型,最后赋给一个String[] 类型的数组。java里不建议整体对数组类型进行转换。
Object[] objects = collection1.toArray();
String[] strings = new String[objects.length];
fTcbR for (int i = 0; i < objects.length; i++) {
strings[i] = (String)objects[i];// 一个一个转,但是没啥必要
}
3、Map 接口
通过< k, v >键值对的形式来存储数据,此处的 key 值唯一,且每个 key 值都可以对应其相应的 value 值。不同的 key 值可以对应相同的 value 。HashMap: 在存放元素时,根据其key值,调用内部的hashCode函数,找到元素该放入的位置,所以哈希表中元素不是按照存入的顺序存放的。
Map常见方法使用
方法作用V get(Object k)根据指定k查找对应vV getOrDefault(Object k, V defaultValue)根据指定的 k 查找对应的 v,没有找到则返回默认值V put(K key, V value)将指定的 k-v 放入 Mapboolean containsKey(Object key)判断是否包含 keyboolean containsValue(Object value)判断是否包含 valueSet
HashMap
// put()
map.put(1,"张飞");// 这里的 key 值唯一
map.put(1,"宋江");// 如果二次插入的 key 值之前有,则替换其 value值
map.put(2,"Jack");
System.out.println(map);
// get()
String s1 = map.get(1);// 返回 宋江
String s3 = map.getOrDefault(3,"三团");// 未找到,返回 三团
// entrySet()
// 该方法返回一个 Set
Set
for (Map.Entry
// 通过 entry.getKey() 和 entry.getValue() 获取每个entry对应的 k, v值
System.out.println(entry.getKey() + " " + entry.getValue());
}
4、具体的实现类
以上就是集合的入门知识啦~
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~