201621123021《JAVA程序设计》第八周学习总结

 

1. 本周学习总结

 

2. 书面作业

1. ArrayList代码分析

1.1 解释ArrayList的contains源代码

public boolean contains(Object o) {
        return indexOf(o) >= 0;
    }

 

  • 根据源码可知contains函数是一种判断数组是否存在某一内容函数,其运用了函数ondexOf,通过判断可知,存在此内容返回true,否则返回false。

1.2 解释E remove(int index)源代码

public E remove(int index) {
        rangeCheck(index);

        modCount++;
        E oldValue = elementData(index);

        int numMoved = size - index - 1;
        if (numMoved > 0)
            System.arraycopy(elementData, index+1, elementData, index,
                             numMoved);
        elementData[--size] = null; // clear to let GC do its work

        return oldValue;
    }

 

  • 根据源码remove函数是通过计算计算数组中该元素的位置,然后使用System.arraycopy()函数的得到调节后的数组,接着把原素组中要删除的元素重置为null。

1.3 结合1.1与1.2,回答ArrayList存储数据时需要考虑元素的具体类型吗?

  • ArrayList存储数据时可以不用考虑基本数据类型,因为ArrayList可以存储的类型是object,而其实所有类的父类,所以如果我们不断ArrayList进行约束,可以不考虑存储数据的类型。

1.4 分析add源代码,回答当内部数组容量不够时,怎么办?

public boolean add(E e) {
        ensureCapacityInternal(size + 1);  // Increments modCount!!
        elementData[size++] = e;
        return true;
    }

 

  • 根据源码我们可知当我们引用add函数时,它首先使用ensureCapacityInternal函数判断是否需要扩容,若是需要扩容引用ensureExplicitCapacity函数。

1.5 分析private void rangeCheck(int index)源代码,为什么该方法应该声明为private而不声明为public?

private void rangeCheck(int index) {
        if (index >= size)
            throw new IndexOutOfBoundsException(outOfBoundsMsg(index));
    }

 

  • 该函数是为了判断数组越界只需要在该类内部使用就可以了,不需要外部也能使用。

2. HashSet原理

2.1 将元素加入HashSet(散列集)中,其存储位置如何确定?需要调用那些方法?

  • 当元素加入散列表时,首先通过hashcode来计算该函数所因存储与哈希表中的位置,但该位置有值是判断两者是否相等,相等则不需要在加入,不相等则需要运用解决哈西冲突的方法来确定下一个位置。
  • 调用方法为计算hashcode的方法和解决哈希冲突的方法。

2.2 将元素加入HashSet中的时间复杂度是多少?是O(n)吗?

  • 元素加入hashset的不是通过遍历来确定位置,而是通过hashcode来计算位置的所以其时间复杂度不是O(n)。

3. ArrayListIntegerStack

3.1 比较自己写的ArrayListIntegerStack与自己在题集jmu-Java-04-面向对象2-进阶-多态、接口与内部类中的题目自定义接口ArrayIntegerStack,有什么不同?

  • 之前写自定义接口实现时大部分的方法都是自己编写并且引用的是固定的数组来存储数据,而这次我编写这段程序时候的确实动态数组ArrayList,其封装性强很多方法都可以调用且数组的长度还是可变的。

3.2 结合该题简单描述接口的好处,需以3.1为例详细说明,不可泛泛而谈。

  • 接口作为抽象方法的集合,能够使我们在不同的情况下实现接口所定义的抽象函数,就ArrayListIntegerStack接口而言,我们就以前的题和现在的题运用不同的形式来实现这些抽象函数,从而体现多态,是接口适应不同的环境。

4. Stack and Queue

4.1 编写函数判断一个给定字符串是否是回文,一定要使用栈(请利用Java集合中已有的类),但不能使用java的Stack类(具体原因自己搜索)与数组。请粘贴你的代码,类名为Main你的学号。

 

4.2 题集jmu-Java-05-集合之银行业务队列简单模拟(只粘贴关键代码)。请务必使用Queue接口,并说明你使用了Queue接口的哪一个实现类?

 

  • 本题使用 LinkedList实现类,以实现Queue接口。

5. 统计文字中的单词数量并按单词的字母顺序排序后输出

题集jmu-Java-05-集合之5-2 统计文字中的单词数量并按单词的字母顺序排序后输出 (作业中不要出现大段代码)

 

5.1 实验总结

  • 本实验使用TreeSet来存储数据,并使单词能够按照字母顺序排序,然后在进行输出。

3.码云及PTA

3.1. 码云代码提交记录

 

3.2 截图PTA题集完成情况图

 

3.3 统计本周完成的代码量

周次总代码量新增代码量总文件数新增文件数
1 0 0 0 0
2 0 0 0 0
3 0 0 0 0
4 437 437 7 7
5 905 468 13 6
6 1294 389 21 8
7 1678 384 30 9
8 2184 506 42 12
posted @ 2017-11-11 17:46  参通  阅读(186)  评论(1编辑  收藏  举报