20175324 2018-2019-2 《Java程序设计》第8周学习总结

本周学习《Java程序设计》第十五章:

    • 泛型:

      • 泛型(Generics)的主要目的是可以建立具有类型安全的集合框架,如链表、散列映射等数据结构。
      • 泛型类声明:class 名称<泛型列表>
      • 泛型类声明对象:类名后多了一对<泛型列表>,必须要用具体的类型替换<>中的泛型
      • LinkedList<String> mylist=new LinkedList<String>();
    • 链表:
      • 链表是由若干个称作节点的对象组成的一种数据结构,每个节点含有一个数据和下一个节点的引用
      • LinkedList泛型类创建的对象以链表结构存储数据,习惯上称LinkedList类创建的对象为链表对象。
      • LinkedList<String> mylist=new LinkedList<String>();创建一个空双链表。
      • add(E obj)向链表依次增加节点。
      • LinkedList泛型类实现Lis泛型接口中的一些常用方法
        • public boolean add(E element)向链表末尾添加一个新的节点,该节点中的数据是参数elememt指定的数据。
        • public void add(int index ,E element)向链表的指定位置添加一个新的节点,该节点中的数据是参数elememt指定的数据。
        • public void clear()删除链表的所有节点,使当前链表成为空链表。
        • public E remove(int index)删除指定位置上的节点。
        • public boolean remove(E element)删除首次出现含有数据elemen的节点。
        • public E get(int index)得到链表中指定位置处节点中的数据。
      • LinkedList泛型类本身新增加的一些常用方法
        • public void addFirst(E element)向链表的头添加新节点,该节点中的数据是参数elememt指定的数据。
        • public void addLast(E element)向链表的末尾添加新节点,该节点中的数据是参数elememt指定的数据。
        • public E getFirst()得到链表中第一个节点中的数据。
        • public E getLast()得到链表中最后一个节点中的数据。
        • public E removeFirst()删除第一个节点,并返回这个节点中的数据。
      • 遍历链表
        • 当用户需要遍历集合中的对象时,应当使用该集合提供的迭代器,而不是让集合本身来遍历其中的对象
        • 链表对象可以使用iterator()方法获取一个Iterator对象,该对象就是针对当前链表的迭代器
        • 构造: Iterator <String> iter=list.iterator()
      • 排序与查找
        Collections类提供的用于排序和查找的类方法如下:

        • public static sort(List<E> list)该方法可以将list中的元素升序排列
        • int binarySearch(List<T> list, T key,CompareTo<T> c)使用折半法查找list是否含有和参数key相等的元素,如果key链表中某个元素相等,方法返回和key相等的元素在链表中的索引位置(链表的索引位置从0考试),否则返回-1
      • 洗牌与旋转
        Collections类还提供了将链表中的数据重新随机排列的类方法以及旋转链表中数据的类方法

        • public static void shuffle(List<E> list)将list中的数据按洗牌算法重新随机排列
        • static void rotate(List<E> list, int distance)旋转链表中的数据
        • public static void reverse(List<E> list)翻转list中的数据
    • 堆栈
      • 堆栈是一种“后进先出”的数据结构,只能在一端进行输入或输出数据的操作。
      • Stack泛型类创建一个堆栈对象,堆栈对象常用方法:
        • public E push(E item);实现压栈操作
        • public E pop();实现弹栈操作
        • public boolean empty();判断堆栈是否还有数据
        • public E peek();获取堆栈顶端的数据,但不删除该数据
        • public int search(Object data);获取数据在堆栈中的位置
    • 散列映射
      • HashMap<K,V>泛型类

        • HashMap<K,V>对象采用散列表这种数据结构存储数据,习惯上称HashMap<K,V>对象为散列映射
      • 常用方法:
        • public void clear()清空散列映射
        • public Object clone()返回当前散列映射的一个克隆
        • public boolean containsKey(Object key)如果散列映射有“键/值”对使用了参数指定的键,方法返回true,否则返回false
        • public boolean containsValue(Object value)如果散列映射有“键/值”对的值是参数指定的值
        • public V put(K key,V value)将键/值对数据存放到散列映射中,该方法同时返回键所对应的值
        • public V get(Object key)返回散列映射中使用key做键的“键/值”对中的值
        • public boolean isEmpty()如果散列映射不含任何“键/值”对,方法返回true,否则返回false
        • public V remove(Object key)删除散列映射中键为参数指定的“键/值”对,并返回键对应的值
        • public int size()返回散列映射的大小,即散列映射中“键/值”对的数目
    • 树集
      • TreeSet<E>泛型类

        • TreeSet<String> mytree=new TreeSe<String>(); TreeSet类创建的对象称作树集
        • mytree.add("boy");使用add方法为树集添加节点
      • TreeSet类的常用方法
        • public boolean add(E o)向树集添加加节点
        • public void clear()删除树集中的所有节点
        • public void contains(Object o)如果树集中有包含参数指定的对象,该方法返回true,否则返回false
        • public E first()返回树集中的第一个节点中的数据(最小的节点)
        • public E last()返回最后一个节点中的数据(最大的节点)
        • public isEmpty()判断是否是空树集,如果树集不含任何节点,该方法返回true
        • public boolean remove(Object o)删除树集中的存储参数指定的对象的最小节点
        • public int size()返回树集中节点的数目
    • 树映射
      • TreeMap<K,V>类实现了Map<K,V>接口,称TreeMap<K,V>对象为树映射。
      • 树映射使用public V put(K key,V value);方法添加节点。

原文地址:https://www.cnblogs.com/wcqy/p/10747077.html

时间: 2024-11-03 05:23:39

20175324 2018-2019-2 《Java程序设计》第8周学习总结的相关文章

20155336 2016-2017-2《JAVA程序设计》第二周学习总结

20155336 2016-2017-2 <JAVA 程序设计>第二周学习总结 教材学习内容 1: GIT版本检测 2: JAVA中基本类型 整数 字节 浮点数 字符 布尔(▲) 通过API可以得知各个类型可存储的数值范围 public class Range {public static void main(String[] args){ //byte.short.int.long的范围 System.out.printf("%d~%d%n", Byte.MIN_VALU

20145201 《Java程序设计》第一周学习总结

# 20145201 <Java程序设计>第一周学习总结 ## 教材学习内容总结 万事开头难,终于开始学习了Java.寒假的时候看到老师的要求确实有点慌,但是这周翻开书,从书本知识第一行学起,发现并不是自己想想中那么难,只要一步一个脚印,每周有自己的计划,并按照计划按部就班的完成,最后一定会拥有自己的小成果的. 1.1Java不只是语言 Java经过多年的版本更新后,最新的版本是Java SE8. 在java发展的过程中,它的应用领域越来越广,根据不同级别的应用开发区分了不同的应用版本,最终j

20145326蔡馨熠《Java程序设计》第一周学习总结

20145326蔡馨熠 <Java程序设计>第一周学习总结 教材学习内容总结 转眼间新的一学期终于开始了!为什么我这么期待呢?因为这学期可以上娄嘉鹏老师的java程序设计课,我不是什么电脑天才,之前c语言学得也不是特别好.可我就是对hdl和java特别感兴趣(之前在我的问卷调查报告里面提到过),并且寒假的时候在家里也预习了一部分java知识.第一周要求学习两个章节并作心得体会,虽然我早已看过前两章的知识,不过为了进一步巩固,我还是用了星期六一天的时间把第一章和第二章的知识从头到尾仔仔细细的看了

20145224-陈颢文 《Java程序设计》第一周学习总结

20145224 <Java程序设计>第一周学习总结 教材学习内容总结 通过第一周的学习让我对Java有了个初步的了解,知道了Java分为Java SE.Java EE.Java ME三大平台,其中Java SE是基础.Java的一大特点是它可以跨平台,而JVM对Java的跨平台提供了支持,它就类似于一个虚拟机,只要在当前平台安装了相应的JVM,Java程序就有了可以在此平台上运行的基础啦.JRE是Java的执行环境,在安装了JRE的计算机上就可以运行Java的程序了,当然光是可以跑代码对于程

20155335 俞昆 2016-2017-2 《Java程序设计》第九周学习总结

学号 2016-2017-2 <Java程序设计>第九周学习总结 ##JDBC入门 在正式介绍JDBC前,已知JDBC是用来执行SQL的解决方案,开发人员使用JDBC的标准接口,开发人员不需接触底层数据库驱动程序的差异性. 本章,我们需要了解JDBC与API使用和概念,我们先要认识应用程序如何与数据库进行沟通,数据库本身是一种独立运行的应用程旭,程序员撰写的应用程序是利用通信协议对数据库进行指令交换,以进行数据的增加删除以及查找. 通常应用程序会利用一组专门与数据库进行通信协议的链接库,以简化

20145326《Java程序设计》第二周学习总结

20145326<Java程序设计>第二周学习总结 教材学习内容总结 本周学习教材第三章,本章主要讲述了java语言中的一些基础语法,java是个支持面向对象的程序语言,但在正式进入面向对象支持语法的探讨前,对于类型.变量.运算符.流程控制等,这些各种程序语言都会有的基本语法元素,还是要有一定的基础.虽然各种程序语言都有这些基本语法元素,但千万别因此而轻忽它们,因为各种程序语言都有其诞生的宗旨与演化过程,对这些基本语法元素,也就会有其独有的特性. 1. 类型 在java的世界中,并非每个东西都

20145201 《Java程序设计》第一周学习总结(修改)

# 20145201 <Java程序设计>第一周学习总结 ## 教材学习内容总结 万事开头难,终于开始学习了Java.寒假的时候看到老师的要求确实有点慌,但是这周翻开书,从书本知识第一行学起,发现并不是自己想想中那么难,只要一步一个脚印,每周有自己的计划,并按照计划按部就班的完成,最后一定会拥有自己的小成果的. 1.1Java不只是语言 Java经过多年的版本更新后,最新的版本是Java SE8. 在java发展的过程中,它的应用领域越来越广,根据不同级别的应用开发区分了不同的应用版本,最终j

20145238-荆玉茗 《Java程序设计》第一周学习总结

20145238 <Java程序设计>第一周学习总结 教材学习内容总结 Java三大平台:由于java领域的应用越来越广,根据不同级别的应用开发区分了不同的应用版本,后正式更名为Java SE,Java EE,Java ME. Java SE主要分为四个部分:JVM,JRE,JDK和JAVA语言. 了解JCP与JSR.RI.TCK的关系:JSR必须经过JCP投票通过才能成为最终的标准文件,JSR成为最终文件后对其成果做出免费且开发原始码的参考实现,称为RI,由TCK作为技术兼容测试工具箱. 了

201521123045 &lt;java程序设计&gt;第11周学习总结

201521123045 <java程序设计>第11周学习总结 1. 本周学习总结 2. 书面作业 2. 书面作业 Q1.1.互斥访问与同步访问完成题集4-4(互斥访问)与4-5(同步访问) import java.util.concurrent.locks.ReentrantLock; import java.util.concurrent.locks.Condition; class Account{ private int balance; private Lock lock = new

20145311 《Java程序设计》第九周学习总结

20145311 <Java程序设计>第九周学习总结 教材学习内容总结 第十六章 整合数据库 16.1JDBC 16.1.1JDBC简介 JDBC(Java DataBase Connectivity)是用于执行SQL的解决方案,开发人员使用JDBC的标准接口,数据库厂商则对接口进行操作,开发人员无须接触底层数据库驱动程序的差异性. 厂商在操作JDBC驱动程序时,依方式可将驱动程序分为4种类型: ·Type 1:JDBC-ODBC Bridge Driver·Type 2:Native API