java对象容器存放的是引用_Java容器

容器:装其他东西的

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

容器相关内容

Java API 所提供的一系列类的实例,用于在程序中存放对象。

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

容器API

1136:一个图  一个类 三个知识点和6个接口(TreeSet TreeMap)

java.util  utili 工具包

接口定义,定义标准。

Collection集合接口  Set集合接口 无顺序 不能重复  List集合 有顺序 能重复(equals返回为true)。

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

接口

重复指的是元素之间相互equals。

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

Collections定义的方法

contains,两个元素equals,而不是 ==  这是引用相等。

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

Collection举例

ArrayList 不指定类型时  可以添加多个类。

父类引用访问子类对象,无法访问子类对象私有的方法。(控制反转)

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

collection 例子1

remove时会和集合内元素 进行 equals (重写equals,不是指向同一引用)比较 ,若为true 则移除。重写equals 就需要重写hashcode

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

比较对象主要用的是equals方法,有的时候需要HashCode方法,对象在Map接口作为索引,作为Key,使用HashCode方法进行比较,效率更高。重写Equals则重写hashCode。相等的对象应具有相同的hashCode方法。hashCode非常适合做索引。

Iterator: 迭代器

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

Iterator接口

所有实现了Collection接口的容器类都有一个iterator方法用以返回一个实现了Iterator接口的对象。Iterator对象称作迭代器(不可反复遍历),用以方便的实现对容器内元素的遍历操作。统一实现不同集合类的遍历操作。

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

ArrayList&LinkedList

List是对外提供的一个接口,容器。ArrayList是使用数组作为底层存储(方便遍历)。LinkedList以链表作为底层存储元素(方便添加)。

多态存在三个必要的条件:

要有继承。要有重写。要有父类引用指向子类对象。

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

Iterator方法举例

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

Iterator方法举例

Iterator对象的remove方法是在迭代过程中删除元素的唯一的安全方法。

Iterator循环遍历过程中,执行了锁定。不允许其他对象进行操作。

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

增强for循环

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

增强for循环

遍历数组的时候 不能方便的访问下标值;

访问集合时,与使用Iterator相比 不能方便的删除集合内容,在内部也是调用Iterator方法。

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

Set接口

实现Set接口的容器类中的元素必须是没有顺序的,而且不可以重复。

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

Set举例

重写equals方法,重写hashCode方法。重复的元素不能填写。

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

Set举例

retainAll  集合之间求交集。无序。

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

List

list非常像数组。可以随便更改容器大小,但是数组不行(需要多次copy)。有顺序,可以重复。List容器中的元素对应一个整数型的序号记载其在容器中的位置,可以根据序号存取容器中的元素。

set方法返回的是旧元素。  indexOf 重写equals  重写hashCode

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

List方法举例

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

Collections

Java.util.Collections提供了一些静态方法实现了基于List容器的一些常用算法。

void sort(List) 对List容器内的元素排序

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

list算法

Collections.shuffle()  Collections.sort()  Collections.reverse() Collections.binarySearch() 静态方法。

Comparable:

通过接口只能看见对象的某一点。

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

Comparable

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

读写效率

Array读快改慢  Linked改快读慢 Hash两者之间

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

Map

键值不能重复(equals  hashCode),HashMap TreeMap

put(key,newvalue)  返回的是 oldValue

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

Map方法举例

autoBoxing_UnBoxing  自动打包

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

自动打包-解包

自动将基础类型转换为对象 -- 打包 ,将对象转换为基础类型 -- 解包

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

自动打包-解包

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

例子1

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

例子2

泛型: Generic

之前类型不明确,装入集合的类型都被当作Object对待,从前失去自己的实际类型。

从集合中取出时往往需要转型,效率低,容易产生错误。

在定义集合的时候 同时定义集合中对象的类型,增强程序的可读性和稳定性。问题越提前越好,尽量不要再运行时出问题。

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

泛型实例1

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

泛型实例2

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

泛型 -自动打包解包

使用到集合尽量使用泛型。

总结

ade09d9d0e0e?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

泛型的可读性和稳定性

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值