容器是什么?通俗的讲容器指可以装其它东西的器皿,前面我们提到的数组便是容器的一种,容器的概念在JAVA中便可以理解为用来存储其它对象的器皿。本篇就让我们一起来认识一下JAVA为我们提供的容器类。

 1、容器API:

  J2SDK提供的容器API位于java.util包内,容器API的类图结构如下图所示:

   

 2、JAVA容器的组成:

  Collection接口——定义了存取一组对象的方法,其子接口Set和List分别定义了存取方式。Set中的数据对象没有顺序但不可以重复;List中的对象有顺序且可以重复,List又被细分为LinkedList和ArrayList,从名字上应该可以看出它的不同,LinkedList以链表的方式来存储数据,ArrayList则以数组的方式来存储数据。说完了Collection接口,下面我们看一下Map接口,Set和List都是单值存储,而Map则提供的是一种键值对的方式存储数据,键和值之间一一映射。

 3、Collection接口定义的方法:

  int size():容器中对象的数目

  boolean isEmpty():是否为空

  void clear():清空

  boolean contains(Object element):是不是包含element对象

  boolean add(Object element):添加element的对象

  boolean remove(Object element):移除element对象

  Iterator iterator():返回一个Iterator对象,用于遍历容器中的对象

  bollean containsAll(Collection c):是否包含c容器中的所有对象

  boolean addAll(Collection c):把c容器中的所有对象添加到容器中

  boolean removeAll(Collection c):从容器中移除C容器中存在的所有对象

  boolean retainAll(Collection c):求当前的集合类与C容器的交集

  Object[] toArray():把容器中的所有对象转换到对应的数组中

 4、Iterator接口:

  所有实现了Collection接口的容器都有一个iterator方法,用于返回一个实现了Itertaor的对象。Iterator对象称为迭代器,用于方便的实现对容器中元素的遍历。

 5、Iterator接口的方法:

  boolean hasNext():判断游标右边是否有元素

  Object next():返回游标右边的元素,并将游标移动到下一个位置。

  void remove():删除游标左边的元素,并将游标移动到下一个位置,该方法一次只能执行一次

public class Iter {
/**
* @param Interator接口
*/
public static void main(String[] args) {
Collection coll = new HashSet();
coll.add(new Integer(1));
coll.add(new Integer(2));
coll.add(new Integer(3));
Iterator it = coll.iterator();
while(it.hasNext()){//判断下一位置是否为空
Integer i = (Integer) it.next();
if(!i.equals(new Integer(1))){
System.out.println(i);
}else{
it.remove();//移除
}
}
}
}

 6、增强的for循环:

  JAVA SDK1.5新增的一个方法,对于遍历array或Collection的时候相当简便。缺陷在于对于数组元素不能方便的访问下标值;对于集合与Iterator相比不能方便的删除容器中的元素。结论:除了简单的遍历和读取其中的内容外,不建议使用增强的for循环。使用方法:

public class test {
/**
* @param 增强for循环
*/
public static void main(String[] args) {
Collection<String> coll = new ArrayList<String>();
coll.add(String.valueOf("a"));
coll.add(String.valueOf("b"));
coll.add(String.valueOf("c"));
for(String str : coll){
System.out.println(str);
}
}
}

 7、Set接口:

  Set接口是Collection接口的子接口,Set接口没有提供额外的方法,但实现了Set接口的容器类中的元素是没有顺序,并且不可以重复的。Set容器类似于数学中集合的概念,J2SDK API中所提供的Set容器类有HashSet和TreeSet等。

public class test {
/**
* @param Set接口
*/
public static void main(String[] args) {
Collection coll = new HashSet();
coll.add("hello");
coll.add("word");
coll.add(new Integer(100));
System.out.println(coll);
}
}

 8、List接口:

  List接口是Collection接口的子接口,List容器的中的元素没有顺序,可以重复。List容器中的元素都对应一个整型序号记载着其在容器中的位置。J2SDK API中所提供的List容器类有ArrayList和LinkList等。

 9、常用方法:

  void sort(List):对List中的元素进行排序

  void shuffle(List):对List中的元素进行随机排序

  void reverse(List):对List中的元素进行逆袭排序

  void fill(List, Object):用一个特定的对象重写List容器

  void copy(List dest, List src):将src容器中的元素拷贝到dest容器中

  int binarySearch(List, Object):对顺序的List容器,采用折半查找法寻找特定的对象

public class test {
/**
* @param List接口
*/
public static void main(String[] args) {
List l1 = new LinkedList();
List l2 = new LinkedList();
for(int i=0; i<5; i++){
l1.add(i+1);
}
for(int i=0; i<5; i++){
l1.add('a');
}
System.out.println(l1);//原始顺序
Collections.shuffle(l1);//随机排序
System.out.println(l1);
Collections.reverse(l1);//倒序排序
System.out.println(l1);
Collections.sort(l1);//排序
System.out.println(l1);
System.out.println(Collections.binarySearch(l1, 3));//折半查找
Collections.copy(l2, l1);//拷贝
System.out.println(l2); }
}

 10、Comparable接口:

  List容器中的元素可以进行排序,那么它是根据什么进行的排序呢?所有可以进行排序的类都实现了java.lang.Comparable接口,Comparable接口只有一个方法:public int CompareTo(Object obj);方法。返回值:0代表this==obj;正数代表this>obj;负数代表this<obj。实现了Comparable接口的类通过实现CompareTo方法从而定义该类对象的排序方法。对姓名排序的例子:

public class Name implements Comparable{
/**
* @param Comparable接口
*/
private String lastName;
private String fastName; public String getLastName() {
return lastName;
} public void setLastName(String lastName) {
this.lastName = lastName;
} public String getFastName() {
return fastName;
} public void setFastName(String fastName) {
this.fastName = fastName;
} public int compareTo(Object arg0) {
Name name = (Name)arg0;
int lastCmp = lastName.compareTo(name.lastName);
return (lastCmp!=0 ? lastCmp : fastName.compareTo(name.fastName));
}
}

 11、Map接口:

  实现了Map接口的类用来存储键--值对,Map中存储的值通过键来标识,故而Map中的键不能重复。

 12、Map常用方法:

  Object put(Object key, Object value):添加元素

  Object get(Object key):取出键值key对应的value值

  Object remove(Object key):移除键值key对应的value值

  boolean containsKey(Object key):判断Map容器中是否存在键值key

  boolean containsValue(Object value):判断Map容器中是否存在value值

  int size():返回Map容器的长度

  boolean isEmpty():判断Map容器是否为空

  void clear():清空Map容器

  对于JAVA容器这一章就总结到这里,对于自动打包和解包、泛型,由于文字描述的局限,就不再这里讨论了,如果你有好的理解,还望留言讨论。

  

javase基础复习攻略《七》的更多相关文章

  1. javase基础复习攻略《一》

    作为一名软件工程专业,JAVA开发方向的大三本科学生,有必要把自己的学到的专业知识进行一下整理,一则方便自己了解自己的学习程度,二则帮助刚刚接触这一门语言的童鞋了解学习,本人来自与河南理工大学,介绍完 ...

  2. javase基础复习攻略《十》

    按照计划本篇为大家总结JAVA的网络编程,什么叫网络编程呢?网络编程!=网站编程,对于这一点大家一定要注意,很多小朋友都曾经这么认为.既然谈到网络编程,咱们先了解一下网络的基础知识,什么是计算机网络? ...

  3. javase基础复习攻略《二》

    今天就开始的真正走进JAVASE的世界,本篇介绍的是:JAVASE基础语法,大家如果有C语言的基础,对于本节内容一定感觉非常轻松,编程语言之间的都是相通的,只不过C语言属于面向过程编程,而JAVA语言 ...

  4. javase基础复习攻略《三》

    编程语言的发展: 机器语言——直接由计算机的指令组成,指令.地址.数据都是以"0"和"1"的符号串组成,可以被计算机直接执行. 汇编语言——用容易理解和记忆的符 ...

  5. javase基础复习攻略《九》

    本篇将为大家总结JAVA中的线程机制,谈到线程,大家一定会问线程和进程有什么区别?刚接触进程时我也有这样的疑问,今天就为大家简单介绍一下进程和线程.进程(Process)是计算机中的程序关于某数据集合 ...

  6. javase基础复习攻略《八》

    进入第八篇,我们开始讨论JAVA的IO初步.在JAVA程序中,对数据的输入\输出操作以"流"(stream)方式进行,J2SDK提供了各种各样的"流"类,用于获 ...

  7. javase基础复习攻略《五》

    总结完JAVA的基础语法和面向对象思想后,今天为大家补充一下JAVA中的数组,数组是什么呢?大家是不是想到了集合,数组和集合有相似之处,集合中的数据无序,不可以重复.数组中则存放着具有相同特征的一组数 ...

  8. javase基础复习攻略《六》

    学习JAVA的同学都知道,sun为我们封装了很多常用类,本篇就为大家总结一下我们经常使用的类.上一篇博客一位朋友留言问我String是不是引用数据类型?我通过查找资料发现String属于应用数据类型, ...

  9. javase基础复习攻略《四》

    本篇内容重点介绍JAVA中的异常处理机制,什么是JAVA异常?JAVA异常是JAVA提供的用于处理程序中错误的一种机制.所谓错误就是指在程序的运行过程中出现的一些异常事件(如:0溢出,数组下表越界,所 ...

随机推荐

  1. VS2010 密钥问题

    密钥:YCFHQ9DWCYDKV88T2TMHG7BHP ①在VS2010安装包中找到setup==>setup.sdb 的Product Key把密钥改为上面的就可以了 ②不想重装那就在控制面 ...

  2. DFS security warning and use group policy to set up internet security zones

    Opening a file from a DFS domain share shows a security warning while openning from the server share ...

  3. c#编程指南(十) 平台调用P-INVOKE完全掌握, 字符串和指针

    可以说新手使用P-INVOKE最开始的头疼就是C#和C++的字符串传递,因为这里涉及到两个问题. 第一:C#的string和C++的字符串首指针如何对应. 第二:字符串还有ANSI和UNICODE(宽 ...

  4. Maltab命令(随用随更新)

    1.eval() ------ 将括号内的字符串视为语句并运行 比如eval('y1=sin(2)')和语句y1=sin(2)等价 多在循环中使用,可以对多个名字有规则的变量或文件进行操作,比如 fo ...

  5. explode,split,preg_split性能比较

      explode,split,preg_split性能比较 分类: php2012-07-12 09:46 1109人阅读 评论(1) 收藏 举报 三个函数都是用来对字符串进行分割,下面分几个实验来 ...

  6. FreeRTOS和Ucos在打开关闭中断的区别

  7. (转)Windows下的Memcached安装与使用

    WHAT Memcached 是一个高性能的分布式内存对象缓存系统,用于动态Web应用以减轻数据库负载.它通过在内存中缓存数据和对象来减少读取数据库的次数,从而提高动态.数据库驱动网站的速度.Memc ...

  8. Git凭证存储(简单易懂,一学就会,认真看)

    今天给自己提了一个问题,当我们在github.com或者gitlab上面新建仓库,并克隆到本地,首次使用的时候,会被问及用户名密码,但是这两个信息存在哪里呢? 带着这个问题,我开始搜索,并在<P ...

  9. Mac中使用port升级gcc版本

    Mac OS中的gcc版本可能不会满足实际使用要求,需要对其升级. 这里介绍使用port方式来升级gcc版本.Macports是Mac OS中的软件包管理工具. 首先,安装Macports 这里提供O ...

  10. vs2010 和vs2012的区别 副标题--Loaded事件走两次

    我上一遍博文没有通过首页显示!这边就简短的描述一下问题,希望大拿们有遇到类似问题或者知道原因的回答一下下!!! 最终的问题是Loaded事件走两次,具体可以看我上一篇对问题的描述. 在目标框架同样都是 ...