知识点:Collection接口、Iterator接口、增强的for循环、Set接口、List接口和Comparable接口、Collection类、Map接口、自动打包/解包、泛型

容器:API文档位于 java.util 包内

容器有这几种:数组、Set、Lish、Map

1、Collection 接口

  • 定义了一组存取对象的方法,存储方式有Set 和 List

    • Set 中的数据对象没有顺序且不可重复
    • List 中的对象有顺序且可以重复
  • Map 接口:定义了存储“键(key)--- 值(value)”映射对的方法

  • Collection 接口所定义的方法:

  • 容器类对象在调用remove、contains等方法时,需要比较两个对象是否equals,这会涉及到对象类型的equals方法和hashCode方法;
  • 对于自定义的类型,需要重写equals和hashCode方法,以实现自定义的对象相等规则
  • 当对象用在Map接口里头作为键(key)使用的时候,会使用hashCode方法(hashCode特别适合用作索引)
  • 重写equals方法,必须重写hashCode方法
  • 两个对象如果互相的equals,则他们两个必须具备相同的hashCode
//remove某个对象的时候,会从容器中挨个将对象取出来与这个对象作比较,如果有对象和这个对象equals,则remove成功
import java.util.*; public class BasicContainer{
public static void main(String args[]){
Collection c = new HashSet(); //用哈希表实现的容器c(父类引用指向子类对象) c.add("hello");
c.remove("hello");//remove成功 //Integer也重写了equals方法,所以只要值一样,这两个对象就就equals
c.add(new Integer());
c.remove(new Integer());//remove成功 c.add(new Name("f1","l1"));
Syetem.out.println(c.remove(new Name("f1","l1")));//返回“false”
//这两个Name对象并不equals,这个Name对象并没有重写equals的情况下,他们两个equals只有一个条件:指向同一对象 System.out.println(c);//
}
} class Name{
private String firstName,lastName;
public Name(String firstName,String lastName){
this.firstName = firstName;
this.lastName = lastName;
} //重写Name对象的equals和hashCode方法如下:
public boolean equals(Object obj){
if (obj instanceof Name){ //如果obj是一个Name对象
Name name = (Name) obj; //将obj强制转换成一个Name对象
return (firstName.equals(name.firstName)) && (lastName.equals(name.lastName));//只有传进来的firstname和lastname都相等时才返回true
}
return super.equals(obj);//如果obj不是一个Name对象,交给父类处理,Name的父类为object。object的equals方法:比较当前对象和传进来的对象是不是同一对象
}
public int hashCode(){
return firstName.hashCode();
}
}

2、Iterator接口

  • 所有实现了Collection接口的容器类都有一个iterator方法,用以返回一个实现了Iterator接口的对象
  • Iterator对象成为迭代器,用以方便的实现对容器内元素的遍历操作
  • Iterator接口就是一个统一用来遍历Collection元素的方法(无论对象是装在数组、链表、哈希表里,但是对于Iterator来说,都是一样的。Iterator就像一个游标,指在第一个元素的左边)

3、Set接口

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

Set类容器有HashSet和TreeSet

4、List 接口

5、Map 接口

实现Map接口的类用来存储 “ 键---值 ” 对

Map接口的实现类有HashMap 和 TreeMap等

Map类中存储的键---值对通过键来标识,所以键值不能重复(互相不能equals,HashCode不能重复)

5、 Comparable接口

6、泛型

在定义集合的时候,同时定义集合中对象的类型

练习:

import.java.util.*;
public class TestArgsWords{
public static void main(args[]){
Map m = new HashMap();
for(int i = 0;i < args.length();i++){ //args是一个数组,循环args
//m.get(args[i]) 以args[i]为key的那个value,如果没有则返回null
int number = (Integer) m.get(args[i]) == null ? 0 : (Integer) a.get(args[i]);//判断是否为空,如果为null就等于0,如果不为空就等于他本身
m.put(args[i],number==0 ? 1 : number + 1);//如果number为0(即m.get(args[i]) == null),则number=0;如果number为1,则为number加1
}
System.out.println(m.size());
Syetem.out.println(m);
}
}
//泛型:(不需要强制转换)
import.java.util.*;
public class TestArgsWords{
public static void main(args[]){
Map<String,Integer> m = new HashMap<String,Integer();
for(int i = 0;i < args.length();i++){ //args是一个数组,循环args
//m.get(args[i]) 以args[i]为key的那个value,如果没有则返回null
int number = m.get(args[i]) == null ? 0 : a.get(args[i]);//判断是否为空,如果为null就等于0,如果不为空就等于他本身
m.put(args[i],number==0 ? 1 : number + 1);//如果number为0(即m.get(args[i]) == null),则number=0;如果number为1,则为number加1
}
System.out.println(m.size());
Syetem.out.println(m);
}
}

J2SE 容器的更多相关文章

  1. [置顶] 【J2SE 】1136 容器之旅

    开篇引言 本篇文章我将要详细的介绍一下什么是容器?以及什么是1136?来系统全面的了解容器,以及容器的应用,下面就进入我们的容器之旅吧! 1.什么是容器? 用来存储和组织其他对象的对象.我们也可以这样 ...

  2. Java面试汇总

    转自:http://zy19982004.iteye.com/blog/1846537#comments 一.All 最近找工作,遇到的笔试面试题,归纳如下,供大家参考. 二.J2SE 容器 Hash ...

  3. J2SE总结(一)-------容器

    最近大家都在讨论容器以及如何在项目中去实际的应用它,由于之前对容器没有什么概念,所以把J2SE里面讲的容器的一些基础知识看了一下,总结一下最基本的东西. 围绕整章最核心的就属下面这张图了吧. 一.概念 ...

  4. Java2_J2EE、J2SE和J2ME的区别

    解析J2EE.J2SE.J2ME.JDK的区别       本文向大家简单介绍一下JDK.J2EE.J2SE.J2ME概念及区别,J2EE,J2SE,J2ME是java针对不同的的使用来提供不同的服务 ...

  5. Eclipse管理Java工程(j2se/j2ee/maven)

    Eclipse管理J2SE/J2EE(Maven)项目 eclipse是一个集成开发工具,有编译,运行,打包部署等功能.eclipse可以新建多种项目,不同的项目有不同的IDE层次结构,方便用户管理资 ...

  6. J2SE J2EE J2ME的区别

    J2SE J2EE J2ME的区别 J2SE J2EE J2ME的区别多数编程语言都有预选编译好的类库以支持各种特定的功能,在Java中,类库以包(package)的形式提供,不同版本的Java提供不 ...

  7. JDK 高性能编程之容器

    高性能编程在对不同场景下对于容器的选择有着非常苛刻的条件,这里记录下前人总结的经验,并对源码进行调试 JDK高性能编程之容器 读书笔记内容部分来源书籍深入理解JVM.互联网等 先放一个类图util,点 ...

  8. jdk,j2ee,j2se,j2me的概念区别

    jdk,j2ee,j2se,j2me的概念区别1.JDK是Java development toolkit,相当于是Java的库函数,是编译,运行java程序的工具包.J2EE是Java 2 ente ...

  9. j2se总结

    j2se总结 经过一周多的时间完成了j2se基础的学习,个人感觉最大的收获不是对j2se的语法了解了多少,而是对面向对象的认识再一次加深了.面向对象,让类和对象成为一切. 下边是对j2se的一部分的总 ...

随机推荐

  1. bzoj3589 动态树 求链并 容斥

    bzoj3589 动态树 链接 bzoj 思路 求链并. 发现只有最多5条链子,可以容斥. 链交求法:链顶是两条链顶深度大的那个,链底是两个链底的\(lca\) 如果链底深度小于链顶,就说明两条链没有 ...

  2. 【CF10D】 LCIS

    题目链接 最长公共上升子序列 \(f[i][j]\)表示\(A\)的前\(i\)个数,匹配\(B\)的第\(j\)个数,且\(B[j]\)必选时的最长公共上升子序列长度 转移: if(A[i]==B[ ...

  3. K8s中的网络

    Kubernetes的网络通信问题: 1. 容器间通信: 即同一个Pod内多个容器间通信,通常使用loopback来实现. 2. Pod间通信: K8s要求,Pod和Pod之间通信必须使用Pod-IP ...

  4. centos 升级openSSH7.81

    1.下载相关依赖包 [root@Log ~]# yum install -y gcc openssl-devel pam-devel rpm-build 2.下载安装包 wget http://ftp ...

  5. Ubuntu 修改apt-get源为阿里源

    原文件重命名备份 sudo mv /etc/apt/sources.list /etc/apt/source.list.bak 编辑源列表文件 sudo vim /etc/apt/sources.li ...

  6. Xamarin.Android DatePickerFragment 日期控件

    MainActivity 代码: public class MainActivity : Activity { TextView _dateDisplay; Button _dateSelectBut ...

  7. Range Sum Query - Mutable 精简无递归线段树

    操作: 单点更新,区间求和 区间求和:如sum [3,10) 需要对19,5,12,26节点求和即可. 观察可知,左端点为右子节点(奇数)时直接相加,右端点为左子节点(偶数)时直接相加,两边向中间移动 ...

  8. python实现根据前序与中序求后序

    我就不板门弄斧了求后序 class Tree(): def __init__(self,x): self.value=x self.left=None self.right=None class So ...

  9. VBA对象模型

    https://www.processon.com/view/link/5d974da6e4b07a0a4d4a098a

  10. HDU校赛 | 2019 Multi-University Training Contest 5

    2019 Multi-University Training Contest 5 http://acm.hdu.edu.cn/contests/contest_show.php?cid=852 100 ...