• 201521123109《java程序设计》第七周学习总结


    1. 本周学习总结

    1.1 以你喜欢的方式(思维导图或其他)归纳总结集合相关内容。

    2. 书面作业

    ArrayList代码分析

    1.1 解释ArrayList的contains源代码

    源代码:

    public boolean contains(Object o) {
        return indexOf(o) >= 0;
    }
    
    public int indexOf(Object o) {
        if (o == null) {
            for (int i = 0; i < size; i++)
                if (elementData[i]==null)
                    return i;
        } else {
            for (int i = 0; i < size; i++)
                if (o.equals(elementData[i]))
                    return i;
        }
        return -1;
    }
    

    判断值o是否为空,若为空,则不可以用equals来比较,如果找到了值o,则返回当前位置,否则返回-1。在源代码自带的注释中也有一句Returns true if this list contains the specified element.即列表中包含指定的特殊元素时,返回True。

    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; 
            return oldValue;
        }
    

    先判断index是否超出size的大小。如果超出,则显示IndexOutOfBoundsException异常。如果未超出,则删除该位置元素,将后面的元素往前移一位,并将最后一位置null。

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

    不需要考虑。因为从上述代码可以看到参数都为Object类型的对象,而Object类是所有类的父类,元素是什么类型都没关系。

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

    见源代码注释:

    public boolean add(E e) {
        ensureCapacityInternal(size + 1);  //调用ensureCapacityInternal()来调整List的容量
        elementData[size++] = e;
        return true;
    }
    private void ensureCapacityInternal(int minCapacity) {
        if (elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA) {
            minCapacity = Math.max(DEFAULT_CAPACITY, minCapacity);
        }
    
        ensureExplicitCapacity(minCapacity);
    }
    private void ensureExplicitCapacity(int minCapacity) {
        modCount++;
    
        // overflow-conscious code
        if (minCapacity - elementData.length > 0)//调用grow()扩容
            grow(minCapacity);
    }
    private void grow(int minCapacity) {
        // overflow-conscious code
        int oldCapacity = elementData.length;
        int newCapacity = oldCapacity + (oldCapacity >> 1);//将原有的数组扩容为1.5倍长度的数组
        if (newCapacity - minCapacity < 0)
            newCapacity = minCapacity;
        if (newCapacity - MAX_ARRAY_SIZE > 0)
            newCapacity = hugeCapacity(minCapacity);
        // minCapacity is usually close to size, so this is a win:
        elementData = Arrays.copyOf(elementData, newCapacity);//将原来的数组元素赋值到新的数组中
    } 
    

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

    源代码:

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

    因为该方法只是判断是否超出界限,外部不需要对它进行修改或者访问,所以没必要声明为public。

    HashSet原理

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

    首先计算出待存储对象的散列码,再以此作为依据确定存储位置;需要调用equals()和hashCode()方法。

    2.2 选做:尝试分析HashSet源代码后,重新解释1.1

    ArrayListIntegerStack

    题集jmu-Java-05-集合之5-1 ArrayListIntegerStack

    3.1 比较自己写的ArrayListIntegerStack与自己在题集jmu-Java-04-面向对象2-进阶-多态、接口与内部类中的题目5-3自定义接口ArrayIntegerStack,有什么不同?(不要出现大段代码)

    首先是栈的实现方法不同,ArrayListIntegerStack用ArrayList实现栈,而ArrayIntegerStack用Integer数组实现栈;其次前者可自动扩容,不需要一开始就要考虑数组长度,而后者需要提前确定数组长度,且用到top指针进行出栈、入栈等操作。

    3.2 简单描述接口的好处.

    一个接口可以操作不同的类,即相同方法,不同实现,灵活性更高了。

    Stack and Queue

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

    public class Main201521123109{
        public static void main(String[] args) {
            Scanner sca=new Scanner(System.in);
            StringStack stack=new ArrayListStringStack();
            String s=sca.next();
            int j=1;
            for(int i=0;i<s.length();i++)
            {
                stack.push(String.valueOf(s.charAt(i)));
            }
            for(int i=0;i<s.length();i++)
            {
                if(!String.valueOf(s.charAt(i)).equals(stack.pop()))j=0;
                else j=1;
            }
            if(j==1)System.out.println("Yes");
            else System.out.println("No");
            }
    
    }
    

    4.2 题集jmu-Java-05-集合之5-6 银行业务队列简单模拟。(不要出现大段代码)

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

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

    5.1 实验总结

    主要是用TreeSet对对象按照字母顺序进行排序。

    选做:加分考察-统计文字中的单词数量并按出现次数排序

    题集jmu-Java-05-集合之5-3 统计文字中的单词数量并按出现次数排序(不要出现大段代码)

    6.1 伪代码

    6.2 实验总结

    面向对象设计大作业-改进

    7.1 完善图形界面(说明与上次作业相比增加与修改了些什么)

    7.2 使用集合类改进大作业

    参考资料:
    JTable参考项目

    3. 码云上代码提交记录及PTA实验总结

    题目集:jmu-Java-05-集合

    3.1. 码云代码提交记录

    在码云的项目中,依次选择“统计-Commits历史-设置时间段”, 然后搜索并截图

    3.2. PTA实验

    •编程(5-1, 5-2, 5-3(选做), 5-6)
    •实验总结已经在作业中体现,不用写。

  • 相关阅读:
    DataTable 类(二)处理表中的数据
    .NET中的正则表达式
    DataTable 类(一)表结果操作
    DataGridView(2)数据操作
    DataGridView(一)
    VS2008中配置 Windows SDK v7
    TabControl
    .NET中的正则表达式 (一)Regex 类
    db2的count()函数和sum()函数的用法
    显示原始字符串
  • 原文地址:https://www.cnblogs.com/yycl/p/6683000.html
Copyright © 2020-2023  润新知