• 20175202 《Java程序设计》第八周学习总结


    20175202 2018-2019-2 Java程序设计》第八周学习总结

    教材知识点总结

    1.泛型:

    主要目的是可以建立具有类型安全的集合框架,如链表、散列映射等数据结构。

    泛型类的声明:class 名称<泛型列表>。

    泛型类声明时,“泛型列表”给出的泛型可以作为类的成员变量的类型、方法的类型以及局部变量的类型。

    泛型类的类体和普通类的类体完全类似,由成员变量和方法构成。

    使用泛型类声明对象:Cone<Circle> coneOne;

                                        coneOne =new Cone<Circle>(new Circle());

    Java泛型的主要目的时可以建立具有类型安全的数据结构。

    2.链表:

    由若干个人称作结点的对象组成的一种数据结构,每个结点含有一个数据和下一个结点的引用。

    习惯上称LinkedList类创建的对象为链表对象。

    无论何种集合,应当允许用户以某种方法遍历集合中的对象,而不需要知道这些对象再集合中是如何表示及存储的。

    链表对象可以使用iterator()方法获取一个Iterator对象,该对象就是针对当前链表的迭代器。

    3.排序与查找:

    public static sort(List<E> list) 该方法可以将list中的元素升序排列。

    int binarySearch(List<T> list, T key,CompareTo<T> c) 使用折半法查找list是否含有和参数key相等的元素,如果key链表中某个元素相等,方法返回和key相等的元素在链表中的索引位置(链表的索引位置从0考试),否则返回-1。

    4.洗牌与旋转:

    public static void shuffle(List<E> list) 将list中的数据按洗牌算法重新随机排列。

    static void rotate(List<E> list, int distance) 旋转链表中的数据,instance大于0向右转动数据,小于0向左转动数据。

    public static void reverse(List<E> list) 翻转list中的数据。

    5.堆栈:

    堆栈是一种“后进先出”的数据结构,只能在一端进行输入或输出数据的操作。

    使用java.util包中的Stack<E>泛型类创建一个堆栈对象,堆栈对象也以使用:

    public E push(E item);实现压栈操作

    public E pop();实现弹栈操作。

    public boolean empty();判断堆栈是否还有数据。

    public E peek();获取堆栈顶端的数据,但不删除该数据。

    public int search(Object data);获取数据在堆栈中的位置。

    6.散列映射:

    HashMap<K,V>对象采用散列表这种数据结构存储数据,习惯上称HashMap<K,V>对象为散列映射。

    该泛型类实现了泛型接口Map<K,V>,可以用接口回调技术,那么接口变量就可以调用类实现的接口方法。

    public void clear() 清空散列映射。

    public Object clone() 返回当前散列映射的一个克隆。

    public boolean containsKey(Object key) 判断散列映射有“键/值”对是否使用了参数指定的键。

    public boolean containsValue(Object value) 判断散列映射有“键/值”对的值是否是参数指定的值。

    public V get(Object key) 返回散列映射中使用key做键的“键/值”对中的值。

    public boolean isEmpty() 判断散列映射是否含任何“键/值”对。

    public V remove(Object key) 删除散列映射中键为参数指定的“键/值”对,并返回键对应的值。

    public int size() 返回散列映射的大小。

    7.树集:

    TreeSet<E>泛型类:适合用于数据的排序

    例如:TreeSet<String> mytree=new TreeSe<String>();

    然后使用add方法为树集添加节点,例如:mytree.add("boy");

    8.树映射:

    TreeMap<K,V>类实现了Map<K,V>接口,称TreeMap<K,V>对象为树映射。

    树映射的结点存储关键字/值对。

     

    教材学习中的问题和解决过程 

    问题1:教材P459中例子11的代码编译无法通过。

    解决方案:之前在输入代码后,我先选择了编译WindowGoods类,结果其使用了Goods,因此须先编写Goods类。先编写Goods类后,问题得到解决。

    问题2:在编写第十五章第3个例子时,显示该Java类文件使用了未经检查或不安全的操作;有关详细信息请使用 -Xlint:unchecked编译。

    解决方案:使用 -Xlint:unchecked编译后,程序即可正确运行。

     

    代码托管

     

    码云链接

    https://gitee.com/GeXuYang/1059724060/commit/ff65675363e33b8958bf8cd4130cf4c98b4e9772

     

    心得体会

      Java课程在这周的任务量很重,不仅要完成第十五章内容的学习,还要完成第二次实验的内容。自己把重心放在了第二次的实验上,认真完成了第二次的实验任务。而在学习第十五章的内容上就显得有点捉襟见肘,大多内容都是蜻蜓点水,一概而过。根本就没有完全理解。下一周要学习的章节内容较少加上有五一假期,自己会好好利用这充裕的时间,来把第十五章的漏洞补上来。

     

    上周错题总结

    上周的测试中无错题。

  • 相关阅读:
    BZOJ3875 AHOI2014/JSOI2014骑士游戏(动态规划)
    Contest 9
    Contest 8
    Codeforces Round#514 Div.2 翻车记
    Contest 7
    安徽师大附中%你赛day6 T3 Hamsters [POI2010]CHO-Hamsters 解题报告
    2018.8 安徽师大附中培训游记
    安徽师大附中%你赛day5 T3 树上行走 解题报告
    安徽师大附中%你赛day4T2 演讲解题报告
    安徽师大附中%你赛day4T1 金字塔 解题报告
  • 原文地址:https://www.cnblogs.com/gexvyang/p/10745334.html
Copyright © 2020-2023  润新知