java 中的容器(札记)
创建容器向上转型为接口的时候,有时候,并不是一定可行的,因为有的实现类,在接口的基础添加了自己的方法;比如:List
接口下面的 LinkedList
自己定义了一些方法 ;
Arrays.asList()
返回值,内部其实是一个 数组
;因此,我们不能对其进行 add 、delete 操作。因为这些操作,会改变数组的尺寸,而数组大小是固定的 ;
List<A1> list = Arrays.asList(new C1(),new A1(),new B1()) ;
// 编译时不会产生任何警告,但是我们运行就会得到一个异常:不支持的操作 ;
list.add(new A1());
在定义 List
的时候,可以使用 Arrays.asList()
的返回值为其赋值;但是在赋值的时候,返回值类型,是根据参数的类型来的,这里会引起问题的;
即使几个参数是一个 继承体系
中的;
如果参数类型和泛型不一致的话,会报错;但是只要有一个参数与泛型匹配,那么就不会再报错 ;
// 类的继承关系
class A1 {}
class B1 extends A1{}
class C1 extends B1 {}
-------------------------------
// error ,因为泛型要求是 A1,但是参数中没有这样 A1类型
List<A1> list = Arrays.asList(new C1(),new B1()) ;
// oK ,只要一个继承体系中,有一个参数是泛型类型,就OK
List<A1> list = Arrays.asList(new C1(),new B1(),new A1()) ;
上面的代码,我们可以看出,很不好,必须要有泛型类型的参数才行,只有其子类,都会报错;
因此我们需要给 Arrays.asList()
提供一个线索 :Arrays.<泛型>asList()
,这样 Arrays.asList() 就会自动的返回泛型指定的类型,而不是去根据参数来返回具体的类型 ;
List<A1> list = Arrays.<A1>asList(new C1(),new B1()) ;
当然我们也可以用 Collections.addAll();
会根据第一个参数类型,直接推导出应该返回的类型 ;
List<A1> list = new ArrayList<>();
Collections.addAll(list,new C1(),new B1());
存储元素:
HashSet HashMap 乱序
TreeSet TreeMap 默认按照自然顺序,我们可以自己传入比较器
LinkedHashSet LinkedHashMap 按照插入顺序
List
中的 remove(xx)
、removeAll(xx)
、indexOf(xx)
等操作,都用到元素的 equals()
方法;因为他们都要判断参数是否在容器里面,这个判断,就需要用到 equals()
方法;
当然上述方法,都有自己的重载版,直接操控角标,那么则用不到 equals()
方法 ;
List
可以在中间插入元素的;想到 List
下面的小弟 LinkedLsit
、ArrayList
就应该不会对其可在中间插入元素的能力感到怀疑 ;
collectionsAll(a,b,c);
对参数的顺序是不关心的 ;
List<A1> list = new ArrayList<>();
list.add(new B1());
C1 c1 = new C1();
C1 c2 = new C1();
B1 b1 = new B1();
Collections.addAll(list,b1,c1,c2);
// 对参数的顺序是不做要求的
List<A1> a1List = Arrays.<A1>asList(c2,c1,b1);
// 输出 true
System.out.println(list.containsAll(a1List));
a.retainAll(b)
查交集 ;
迭代器(Iterator
)的出现,统一了对容器的遍历操作;
因为,迭代器的方法:haveNext()
、next()
;根本就没有出现对具体容器操作的代码;后期即使改变了容器,迭代器的代码也不用改变 ;
Iterator
迭代器,只能 单向遍历,但是可以遍历任意容器;
ListIterator
只能遍历 List
集合;但是可以 双向遍历,也可以从任何一个位置开始遍历;还可以返回当前位置的前一个、后一个位置的索引 ;
Set
与 Collection
具有一样的接口,不像 List
那样,自己添加了一些方法 ;
HashSet
维护着一个散列函数,该散列函数决定了元素的次序;
TreeSet
里面维护着红黑树;
Collection
接口 AND Iterator
方法
Collection 接口中有许多方法,假如我们要实现这个接口,那么我们将要实现一大堆方法,尽管其中有些方法,我们并不想用;
官方也考虑到这个问题,因此,官方给出来一个 Collection
接口的直接抽象子类 AbstractCollection
,这样我们就只需要实现 两个方法 iterator() 、size()
即可 ;
class D1 extends AbstractCollection{
@Override
public Iterator iterator() {
return null;
}
@Override
public int size() {
return 0;
}
}
foreach
增强for循环
只对 数组
和 实现了 Iterator
接口,起作用 ;但是并不是 数组
是 Iterator
类型 ;
Arrays.asList(c2,c1,b1)
返回值底层是一个数组,对返回值的操作,将直接影响到原数组 ;因此,一次操作是不允许的,比如 add(()、remove()
等方法 ;
如果对返回值进行操作,那么同样影响到原数组 ;
Integer[] integer = {1,22,33,4,56,21};
List<Integer> a1List = Arrays.asList(integer);
a1List.set(0,12) ;
// 输出的是 12 而不是 1 ;
System.out.println(integer[0]);
如果实在需要操作,可以将返回值转成一个真正的 List 类型 ;
List<A1> a1List = Arrays.<A1>asList(c2, c1, b1);
List<A1> a1List1 = new ArrayList<>(a1List);
// 添加元素
a1List1.add(new A1()) ;
// 改变元素组。。
java 中的容器(札记)的更多相关文章
- java中的容器问题
小小的总结一下java中的容器问题. 一.三个知识点 1.迭代器 1).java.util.Interator + hasnext(); next(); remove(); 2).java.lang. ...
- Java中的容器(集合)之ArrayList源码解析
1.ArrayList源码解析 源码解析: 如下源码来自JDK8(如需查看ArrayList扩容源码解析请跳转至<Java中的容器(集合)>第十条):. package java.util ...
- Java中的容器(集合)之HashMap源码解析
1.HashMap源码解析(JDK8) 基础原理: 对比上一篇<Java中的容器(集合)之ArrayList源码解析>而言,本篇只解析HashMap常用的核心方法的源码. HashMap是 ...
- (转)Java中的容器详细总结
Java中的容器详细总结(编辑中) 原文链接:http://anxpp.com/index.php/archives/656/ 注:本文基于 Jdk1.8 编写 通常程序总是根据运行时才知道的某些条件 ...
- [转] Java中的容器
在书写程序的时候,我们常常需要对大量的对象引用进行管理.为了实现有效的归类管理,我们常常将同类的引用放置在同一数据容器中. 由于数据容器中存放了我们随时可能需要使用到的对象引用,所以一般的数据容器要都 ...
- java中Collection容器
1.容器(Collection)也称为集合, 在java中就是指对象的集合. 容器里存放的都只能是对象. 实际上是存放对象的指针(头部地址): 这里对于八种基本数据类型,在集合中实际存的是对应的包装类 ...
- Java中的容器和注入分析
为什么会出现容器的注入? 容器:顾名思义,装东西的器物. 至于spring中bean,aop,ioc等一些都只是实现的方式:具体容器哪些值得我们借鉴,我个人觉得是封装的思想.将你一个独立的系统功能放到 ...
- java中的容器解释
解释一:容器(Container)Spring 提供容器功能,容器可以管理对象的生命周期.对象与对象之间的依赖关系,您可以使用一个配置文件(通常是XML),在上面定义好对象的名称.如何产生(Proto ...
- Java中的容器(集合)
1.Java常用容器:List,Set,Map List: 继承了Collection接口(public interface List<E> extends Collection<E ...
随机推荐
- docker容器里面执行top报“TERM environment variable not set.”
解决: [hadoop@master ~]$ docker exec -ti 6eca7d27a988 /bin/bashroot@6eca7d27a988:/# topTERM environmen ...
- avalon.js中使用owl-carousel轮播图
<?php if($banners){?> <div class="ms-controller" ms-controller="bannerShow ...
- fdisk交互
fdisk交互 命令 说明 指令 a 设置可引导标记 toggle a bootable flag b 编辑bsd磁盘标签 edit bsd disklabel c 设置DOS操作系统兼容标记 tog ...
- 如何从DOS命令窗口进行复制粘贴
在DOS窗口没有右键复制按钮,那我们如果想要进行复制粘贴该如何操作呢?本篇就来说明一下这个操作流程. 工具/原料 WIN7系统 方法/步骤 按“WIN+R”调出运行页面,在其中输入CMD然 ...
- Lasso回归的坐标下降法推导
目标函数 Lasso相当于带有L1正则化项的线性回归.先看下目标函数:RSS(w)+λ∥w∥1=∑Ni=0(yi−∑Dj=0wjhj(xi))2+λ∑Dj=0∣wj∣RSS(w)+λ∥w∥1=∑i=0 ...
- Linux中 mkdir 创建文件夹命令
语法 mkdir (选项)(参数) 选项 -Z:设置安全上下文,当使用SELinux时有效: -m<目标属性>或--mode<目标属性>建立目录的同时设置目录的权限: -p或- ...
- hystrix流程图收藏
最近在看张开涛的亿级流量的书,学习了一个新的防雪崩的功能hystrix,在学习这个功能的过程中,看了一些网站也温习了一些知识,例如double_check locking功能,还有cache的击穿作为 ...
- nginx中获取真实的客户端访问IP
date : 2019-06-28 16:54:50 author: headsen chen notice: 个人原创 1,必需要先搞清楚的基本概念 1.1 什么是remote_addr ...
- SQL-W3School-函数:SQL HAVING 子句
ylbtech-SQL-W3School-函数:SQL HAVING 子句 1.返回顶部 1. HAVING 子句 在 SQL 中增加 HAVING 子句原因是,WHERE 关键字无法与合计函数一起使 ...
- Android高频单词
Display 显示 Camera 照相机 Bluetooth 蓝牙 Flash Memory 闪存 Audio 音频 Management 管理 SurFace 界面 Media 多媒体 Frame ...