`
h389301776
  • 浏览: 9280 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

第七章:容器 的学习

 
阅读更多

第七章:容器

主要内容:

1.容器的概念 2.容器API 3.Collection接口 4.增强版的for循环

5.Set接口 6.List接口Comparable 接口 7.Collections 8.Map 接口 9.自动打包/解包 10.泛型

1. .容器的概念

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

 

2.容器API

容器API位于java.util包内。

结构如下:

Collection 

      Set    HashSet

      List   LinkedListArrayList

 

Map          HashMap

 

3.Collection接口

Collection接口定义了存取一组对象的方法,其子接口setlist分别定义了存储方式。

Set中的数据对象没有顺序且不可以重复。

List中的数据对象有顺序且可以重复。

Map接口定义了存储“键(key值(value对”的方法。

Collection接口中具体方法参考API文档

容器类对象在调用removecontains等方法时需要比较对象是否相等,这会涉及到对象类型的equals方法和hashcode方法;对于自定义的类型,需要重写equalshashcode方法以实现自定义的对象相等规则,注意:相等的对象应该具有相等的hashcodes.

增加Name类的equalshashcode方法如下:

public boolean equals(Object obj) {     //修改equals方法

        if (obj instanceof Name) {

            Name name = (Name) obj;

            return (firstName.equals(name.firstName))

                    && (lastName.equals(name.lastName));

        }

        return super.equals(obj);

    }

    public int hashCode() {   //修改hashacode方法

        return firstName.hashCode();

}

4. Iterator接口

所有实现了Collection接口的容器类都有一个iterator方法用以返回一个实现了Iterator接口的对象。

Iterator对象称作迭代器,用以方面的实现对容器内元素的遍历操作。

Iterator接口定义了如下方法:

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

object  next( ); //返回游标右边的元素并将游标移动到下一个位置

void remove();//删除游标左面的元素,在执行完next之后该操作只能执行一次

 

 

5.增强版的for循环

增强版的for循环对于遍历arraycollection的时候相当简单

缺陷:

数组:不能方便的访问下标值

集合:与使用iterator相比,不能方便的删除集合中的内容

总结:除了简单遍历并读出其中的内容外不建议使用增强for

例子:

import java.util.*;

 

public class EnhancedFor {

    public static void main(String[] args) {

        int[] arr = {1, 2, 3, 4, 5};

        for(int i : arr) {   //for循环遍历

            System.out.print(" "+i);

        }

        System.out.println();

 

        Collection c = new ArrayList();

        c.add(new String("aaa"));

        c.add(new String("bbb"));

        c.add(new String("ccc"));

        for(Object o : c) {   //for循环遍历

            System.out.print(" "+o);

        }

    }

}

//1 2 3 4 5

// aaa bbb ccc

 

6.Set接口

Set接口是collection的子接口,set接口没有提供额外的方法,但实现set接口的容器类中的元素是没有顺序的,而且不可以重复。

Set容器可以与数学中“集合”的概念相对应。

J2SDK API中所提供的set容器类有HashSet,TreeSet等。

 

retainAll()取交集

addAll() 取并集

 

7. List接口

List接口是Collection的子接口,实现List接口的容器类中的元素是有顺序的,而且可以重复。

List容器中的元素都对应一个整数型的序号记载其在容器中的位置,可以根据序号存取容器的元素。

J2SDK 所提供的List容器类有ArrayList,LinkedList等,

 

8.collections中提供了List容器的算法

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

Void sort (List) list容器内的元素排序

Void shuffle(List) List容器内的对象进行随机排序

Void reverseList)对于List容器内的对象进行逆序排列

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

Void copy List dest, List src)将src List容器拷贝到dest List容器

Int binarySearch(List, object) 对于顺序的List容器,采用折半查找的方法查找特定对象

 

 

 

9.Comparable接口比较对象大小

Java.lang.Comparable接口中只有一个方法:

 Public int compateTo(object obj)

 返回0表示this = = obj

 返回正数表示this > obj

 返回负值表示this < obj

 

例子:

class Name implements Comparable {

    private String firstName,lastName;

    public Name(String firstName, String lastName) {

        this.firstName = firstName; this.lastName = lastName;

    }

    public String getFirstName() {  return firstName;   }

    public String getLastName() {   return lastName;   }

    public String toString() {  return firstName + " " + lastName;  }

 

    public boolean equals(Object obj) {     //修改equals方法

        if (obj instanceof Name) {

            Name name = (Name) obj;

            return (firstName.equals(name.firstName))

                    && (lastName.equals(name.lastName));

        }

        return super.equals(obj);

    }

    public int hashCode() {   //修改hashacode方法

        return firstName.hashCode();

    }

 

 

 

    public int compareTo(Object o) {

        Name n = (Name)o;

        int lastCmp =

                lastName.compareTo(n.lastName);

        return

                (lastCmp!=0 ? lastCmp :

                        firstName.compareTo(n.firstName));

    }

 

}

 

 

如何选择数据结构:

衡量标准:读的效率和改的效率

Array读快改慢

Linked该快读慢

Hash两者之间

 

10.Map接口

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

Map接口实现类有HashMapTreeMap

键值不能重复

例子:

 

import java.util.*;

public class TestMap {

    public static void main(String args[]) {

        Map m1 = new HashMap();

        Map m2 = new TreeMap();

        //m1.put("one",new Integer(1));

        m1.put("one", 1);//自动打包

        //m1.put("two",new Integer(2));

        m1.put("two", 2);

        //m1.put("three",new Integer(3));

        m1.put("three", 3);

        //m2.put("A",new Integer(1));

        m2.put("A", 1);

        //m2.put("B",new Integer(2));

        m2.put("B", 2);

        System.out.println(m1.size());

        System.out.println(m1.containsKey("one")); //是否包含键

        System.out.println

                //(m2.containsValue(new Integer(1)));

                (m2.containsValue(1));//是否包含值

        if(m1.containsKey("two")) {

            //int i = ((Integer)m1.get("two")).intValue();

            int i = (Integer)m1.get("two");//自动解包

            System.out.println(i);

        }

        Map m3 = new HashMap(m1);

        m3.putAll(m2);

        System.out.println(m3);

    }

}

/*

3

true

true

2

{A=1, B=2, two=2, three=3, one=1}

*/

 

11.打包、解包 Auto-boxing/unboxing

在合适的时机自动打包、解包

自动将基础类型转换为对象

自动将对象转换为基础类型

 

例子:

 

import java.util.*;

public class TestMap2 {

    public static void main(String args[]) {

        Map<String, Integer> m1 = new HashMap<String , Integer>();

        m1.put("one", 1);//自动打包

        m1.put("two", 2);

        m1.put("three", 3);

 

        System.out.println(m1.size());

        System.out.println(m1.containsKey("one")); //是否包含键

 

        if(m1.containsKey("two")) { //自动打包

            //int i = ((Integer)m1.get("two")).intValue();

            int i = m1.get("two"); //自动解包对应的值

            System.out.println(i);

        }

 

    }

}

/*

3

true

2

*/

 

12.泛型

增强了可读性和稳定性

在集合中同事定义集合中对象的类型

 

例子:

import java.util.*;

 

public class BasicGeneric {

    public static void main(String[] args) {

        List<String> c = new ArrayList<String>(); //泛型

        c.add("aaa");

        c.add("bbb");

        c.add("ccc");

        for(int i=0; i<c.size(); i++) {

            String s = c.get(i);

            System.out.println(s);

        }

 

        Collection<String> c2 = new HashSet<String>();//泛型

        c2.add("aaa"); c2.add("bbb"); c2.add("ccc");

        for(Iterator<String> it = c2.iterator(); it.hasNext(); ) { //泛型

            String s = it.next();

            System.out.println(s);

        }

    }

}

 

class MyName implements Comparable<MyName> { //泛型

    int age;

 

    public int compareTo(MyName mn) {

        if(this.age > mn.age) return 1;

        else if(this.age < mn.age) return -1;

        else return 0;

    }

}

/*

aaa

bbb

ccc

aaa

ccc

bbb

 

 */

 

 

分享到:
评论

相关推荐

    马士兵J2SE第七章容器个人学习笔记.pdf

    马士兵J2SE第七章容器个人学习笔记.pdf

    Kubernetes K8s 架构师实训营

    从K8s基础入门到K8s项目实战,一条龙学习路径帮你学透K8s,成为K8s高级工程师,突破年薪30W! 第1章:Ansible自动化部署K8S集群;...第7章:基于K8S构建企业JenkinsCICD平台(微服务) 第8章:服务治理Istio初探 其他章节

    java各知识点详细总结(毕向东笔记整理)

    3-11 第二章:数组 11 -31 第三章:面向对象程序开发 31 -74 第四章:异常机制 74 -89 第五章:多线程技术 89 -122122122 第六章:常用类 API 122API 122 API 122API 122API 122API 122API 122-139139139 第七章:...

    C++_GUI_Programming_with_Qt_4_CH

    第七章.事件处理 第八章.2D和3D绘图 第九章.拖拽和扔放操作 第十章. “项浏览”类 第十一章.容器类 第十二章.输入输出 第十三章.数据库 第十四章.网络 第十五章.XML 第十六章.在线帮助 第三部分:高级QT 第十七章:...

    Java开发详解.zip

    020701_【第7章:异常的基本概念】_异常的基本概念笔记.pdf 020702_【第7章:异常的基本概念】_异常的其他概念笔记.pdf 020801_【第8章:包及访问控制权限】_包的定义及导入笔记.pdf 020802_【第8章:包及访问控制...

    Spring+3.x企业应用开发实战光盘源码(全)

     第7章:对如何使用基于AspectJ配置AOP的知识进行了深入的分析,这包括使用XML Schema配置文件、使用注解进行配置等内容。  第8章:介绍了Spring所提供的DAO封装层,这包括Spring DAO的异常体系、数据访问模板等...

    C++ 后台工程师面试宝典

    第七章:事务 第八章:分布式系统的麻烦 设计模式 [C++设计模式] C++单例模式 用C++设计一个不能被继承的类 如何定义一个只能在堆上定义对象的类?栈上呢 重类构造和析构的顺序 操作系统 计算机操作系统复习 linux ...

    陈开雄 Spring+3.x企业应用开发实战光盘源码.zip

     第7章:对如何使用基于AspectJ配置AOP的知识进行了深入的分析,这包括使用XML Schema配置文件、使用注解进行配置等内容。  第8章:介绍了Spring所提供的DAO封装层,这包括Spring DAO的异常体系、数据访问模板等...

    Java语言基础下载

    第七章:类的高级特征 103 学习目标 103 static关键字 104 final关键字 106 内部类 106 实例分析 110 抽象类,接口 115 内容总结 120 独立实践 121 第八章:异常 122 学习目标 122 异常的概念 123 异常的分类 123 ...

    机器视觉.pdf 伯特霍尔德.霍恩 高清带书签完整版[98M]

    第 7 章 图像处理:离散图像 第 8 章 边缘和边缘查找 第 9 章 光照与颜色 第 10 章 反射图:光度立体视觉 第 11 章 从明暗恢复形状 第 12 章 运动场和光流 第 13 章 摄影测量和立体视觉 第 14 章 ...

    21天学会C++精品付费视频教程

    本课程是C++语言的经典课程,每天只需要一小时就可以学会使用C++进行编程所需要的全部技能,内容包括C++和面向对象的...第18讲 第7章控制程序流程:switch语句 第19讲 小结:语句、函数、类型 第20讲 第8章C语言中的

    电子书:Maya特效经典案例总动员

    第7章 MEL脚本特效 第8章 粒子运动轨迹 第9章 表达式特效制作 第10章 合成3D物体 第11章 用粒子创建飞船舰队 第12章 动力学布料特效 第13章 流体火焰特效 第14章 PaintEffects特效 第15章 粒子特效应用 第16章 用...

    C++ STL 开发技术导引(随书源码)

    第7章 deque双端队列容器 第8章 list双向链表容器 第9章 slist单向链表容器 第10章 bit_vector位向量容器 第11章 set集合容器 第12章 multiset多重集合容器 第13章 map映照容器 第14章 multimap多重映照容器 第15章 ...

    《精通Spring2.X企业应用开发详解》16-19章

    Spring容器高级主题 第6章 Spring AOP基础 第7章 基于@AspectJ和Schema的 第7章 AOP 第3篇 数据库访问 第8章 Spring对DAO的支持 第9章 Spring的事务管理 第10章 使用Spring JDBC访问数据库 ...

    《精通Spring2.X企业应用开发详解》随书源码1-15章

    Spring容器高级主题 第6章 Spring AOP基础 第7章 基于@AspectJ和Schema的 第7章 AOP 第3篇 数据库访问 第8章 Spring对DAO的支持 第9章 Spring的事务管理 第10章 使用Spring JDBC访问数据库 ...

    Servlet和Jsp学习指南(带详细书签)

    第5~7章分别阐述jstl中最重要的类库、标签的具体编写方法和标签文件;第8~10章讨论servlet中的事件驱动编程、过滤器,以及model 2架构;第11章展示如何利用servlet 3的文件上传特性,以及如何在客户端改善用户的体验...

    计算机应用基础第02章--Windows7应用.pptx

    2 Windows 7的桌面 桌面图标 7 系统图标 快捷图标 计算机应用基础第02章--Windows7应用全文共37页,当前为第7页。 2 Windows 7的桌面 桌面图标 常用系统图标: "计算机" "回收站":还原、清空 8 图2.3 "回收站"窗口 ...

    最新ThinkPHP 5.1全球首发视频教程

    第7章模板继承与创建数据表 第8章验证器与独立验证 第9章如何查手册学习 第10章前端页面与用户注册 第11章用户登录与验证 第12章文章模型验证与发布 第13章首页列表页处理 第14章搜索与详情页制作 第15章收藏与后台...

    最新ThinkPHP 5.1视频教程

    第7章模板继承与创建数据表 第8章验证器与独立验证 第9章如何查手册学习 第10章前端页面与用户注册 第11章用户登录与验证 第12章文章模型验证与发布 第13章首页列表页处理 第14章搜索与详情页制作 第15章收藏与后台...

    C++ Qt设计模式(第2版)

    第7章 库与设计模式 163 第8章 QObject, QApplication,信号和槽 179 第9章 窗件和设计师 195 第10章 主窗口和动作 225 第11章 范型和容器 246 第12章 元对象,属性和反射编程 262 第13章 模型和视图 277 第...

Global site tag (gtag.js) - Google Analytics