4.7学习总结 java集合进阶

集合进阶

泛型

复制代码
//没有泛型的时候,集合如何存储数据
//结论:
//如果我们没有给集合指定类型,默认认为所有的数据类型都是object类型
//此时可以往集合添加任意的数据类型。
//带来一个坏处:我们在获取数据的时候,无法使用他的特有行为。
//此时推出了泛型,可以在添加数据的时候就把类型进行统
//而且我们在获取数据的时候,也省的强转了,非常的方便,
//1.创建集合的对象
ArrayList<string>list = new ArrayList<>();
//2.添加数据
//list.add(123);
list.add("aaa");
//list.add(new student("zhangsan",123));
//3.遍历集合获取里面的每一个元素
Iterator<string>it = list.iterator();
while(it.hasNext()){
String str = it.next();
//多态的弊端是不能访问子类的特有功能
//obj.length();
//str.length();
System.out.println(str);

泛型可以在很多地方进行定义:

类后面定义:泛型类

方法上面定义:泛型方法

接口后面定义:泛型接口

泛型类:

泛型方法

此时,泛型里面写的是什么类型,那么只能传递什么类型的数据。

弊端:

利用泛型方法有一个小弊端,此时他可以接受任意的数据类型

Student

Ye Fu zi

希望:本方法虽然不确定类型,但是以后我希望只能传递YeFuzi

此时我们就可以使用泛型的通配符:

?也表示不确定的类型

他可以进行类型的限定

?extendsE:表示可以传递E或者E所有的子类类型

?super E:表示可以传递E或者E所有的父类类型

泛型接口

二叉树的遍历:

前序遍历:从根结点开始,然后按照当前结点,左子结点,右子结点的顺序遍历

数中序遍历:从最左边的子节点开始,然后按照左子结点,当前结点,右子结点的顺序遍历

后序遍历:从最左边的子节点开始,然后按照左子结点,当前结点的顺序遍历

层序遍历:一层一层的去遍历

数据结构(平衡二叉树):

规则:任意节点左右子树高度差不超过1

Set系列集合

int index =( 数组长度-1)& 哈希值;

当数组中元素数量达到数组长度*加载因的时候,数组会扩容为原来的两倍

当链表长度大于8而且数组长度大于等于64时,当前链表会自动转成红黑树,提高查找效率。

如果集合中储存的时自定义对象,必须要重写hashCode和equals方法

否则比较的是地址值,一般没有实际意义

LinkedHashSet

TreeSet

总结

相关推荐
STLearner7 小时前
AI论文速读 | U-Cast:学习高维时间序列预测的层次结构
大数据·论文阅读·人工智能·深度学习·学习·机器学习·数据挖掘
黑客思维者8 小时前
LLM底层原理学习笔记:Adam优化器为何能征服巨型模型成为深度学习的“速度与稳定之王”
笔记·深度学习·学习·llm·adam优化器
kk哥88998 小时前
Swift底层原理学习笔记
笔记·学习·swift
AA陈超10 小时前
Lyra学习004:GameFeatureData分析
c++·笔记·学习·ue5·虚幻引擎
zkl_zkl_11 小时前
地理信息系统学习笔记——第六章 空间数据采集与处理
笔记·学习·数据处理·数据质量·空间数据
光头程序员11 小时前
学习笔记——主攻 vite
笔记·学习
零匠学堂202511 小时前
移动学习系统,如何提升企业培训效果?
java·开发语言·spring boot·学习·音视频
TL滕12 小时前
从0开始学算法——第四天(题目参考答案)
数据结构·笔记·python·学习·算法
Hoshino.4112 小时前
从0开始学习Linux——第七部分:DNS(1)
linux·网络·学习
TL滕13 小时前
从0开始学算法——第四天(练点题吧)
数据结构·笔记·学习·算法