1. 本周学习总结

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

2. 书面作业

1. ArrayList代码分析

1.1 解释ArrayList的contains源代码

  • 查看ArrayList的contains源代码
  1. public boolean contains(Object o) {
  2. return indexOf(o) >= 0;
  3. }
  4. public int indexOf(Object o) {
  5. if (o == null) {
  6. for (int i = 0; i < size; i++)
  7. if (elementData[i]==null)
  8. return i;
  9. } else {
  10. for (int i = 0; i < size; i++)
  11. if (o.equals(elementData[i]))
  12. return i;
  13. }
  14. return -1;
  15. }

contains解释为包含,对顺序列表进行遍历,查看是否存在与参数o相同值的元素。当传入的参数为null时,对顺序列表进行遍历,若有值为null的元素,则返回其下标(单独出来的原因是null表示没有引用对象,不能使用equals方法);若传入的参数非空,对顺序列表进行遍历,若有值与传入的参数值相同的元素,则返回其下标;若遍历后未发现相同的值,则返回-1。

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

  • 查看E remove(int index)源代码
  1. public E remove(int index) {
  2. rangeCheck(index);
  3. modCount++;
  4. E oldValue = elementData(index);
  5. int numMoved = size - index - 1;
  6. if (numMoved > 0)
  7. System.arraycopy(elementData, index+1, elementData, index,
  8. numMoved);
  9. elementData[--size] = null; // clear to let GC do its work
  10. return oldValue;
  11. }

remove解释为移除,传入的参数为顺序列表的下标,如果下标小于元素个数,将其元素值存入oldValue中,若下标小于(元素个数-1)时,则将该元素后面的所有元素进行往前移,即移除该元素;下标等于(元素个数-1)时,无需移动,最后将列表的最后一位元素置为null,返回移除的元素的值。

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

不需要考虑元素的类型。ArrayList存储的元素类型为Object。所有类的父类都是Object类,所以所有对象都是Object的实例化,J2SE5.0开始提供自动装箱\拆箱的支持,在此支持下无需考虑元素类型为基本类型的情况,自动将基本类型转化为相应的引用类型。在定义的时候要写引用类型,添加的时候无需考虑。集合中存放的是对象的引用,实际内容都在堆上面或者方法区里面,但是基本数据类型是在栈上分配空间的,可随时被收回。

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

  • 查看add源代码
  1. public boolean add(E e) {
  2. ensureCapacityInternal(size + 1); // Increments modCount!!
  3. elementData[size++] = e;
  4. return true;
  5. }
  6. private void ensureCapacityInternal(int minCapacity) {
  7. if (elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA) {
  8. minCapacity = Math.max(DEFAULT_CAPACITY, minCapacity);
  9. }
  10. ensureExplicitCapacity(minCapacity);
  11. }
  12. private void ensureExplicitCapacity(int minCapacity) {
  13. modCount++;
  14. // overflow-conscious code
  15. if (minCapacity - elementData.length > 0)
  16. grow(minCapacity);
  17. }
  18. private void grow(int minCapacity) {
  19. // overflow-conscious code
  20. int oldCapacity = elementData.length;
  21. int newCapacity = oldCapacity + (oldCapacity >> 1);
  22. if (newCapacity - minCapacity < 0)
  23. newCapacity = minCapacity;
  24. if (newCapacity - MAX_ARRAY_SIZE > 0)
  25. newCapacity = hugeCapacity(minCapacity);
  26. // minCapacity is usually close to size, so this is a win:
  27. elementData = Arrays.copyOf(elementData, newCapacity);
  28. }

注释Increments modCount!!解释为数组容量加一,通过ensureCapacityInternal方法对数组容量进行扩展(主要使用grow方法)。在传入的参数与常量DEFAULT_CAPACITY(值为10)之间选取最大的值,作为数组的容量,可知,默认数组容量为10,当数组的逻辑长度超过10则数组容量等同于数组的逻辑长度。数组容量和数组的逻辑长度是不同的概念

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

  • 查看private void rangeCheck(int index)源代码
  1. private void rangeCheck(int index) {
  2. if (index >= size)
  3. throw new IndexOutOfBoundsException(outOfBoundsMsg(index));
  4. }

rangeCheck解释为检查是否超出范围。传入的参数为数组元素的下标,当下标满足小于数组长度时,不做任何操作;下标大于等于数组长度时,表示超出范围。方法权限声明为private时表示该方法只限在类内使用,提高方法的安全性,防止外部人员对进行修改。

2. HashSet原理

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

首先使用hashCode(),计算出元素的哈希码->根据哈希码找到散列表中对应的列表(称为桶)->如果桶中有其他元素则调用equals()与已有元素进行比较,否则直接添加->比较结果为假时,将元素插入桶中,否则,用元素的值取代旧的值。两个元素用equals方法比较结果为true时,他们的hashCode()返回的值也相同->保证相同的值不被重复添加

3. ArrayListIntegerStack

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

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

ArrayList中无需使用变量top,因为top始终等于数组的容量大小,且数组的容量大小会随着元素的增减而发生变化,在Array中需要对top进行操作;在编写push函数时,ArrayList无需考虑是否会出栈,因为顺序列表的容量分配是动态的。

3.2 简单描述接口的好处.

接口是包含抽象方法的抽象类,用来描述实现它的类的共有特性。将接口的抽象方法和实现它的类中具体实现方法进行分离,接口可被多个类实现,当要对共同特性进行修改时,只需在接口中修改,简化操作。ArrayListIntegerStack和ArrayIntegerStack都实现了IntegerStack接口。

4. Stack and Queue

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

  1. public class Main201521123037 {
  2. public static void main(String[] args) {
  3. ArrayListIntegerStack list=new ArrayListIntegerStack();//使用之前的ArrayListIntegerStack类,将存储的元素类型改为String
  4. String str1="abccba";
  5. String str2="abccbs";
  6. System.out.println(huiwen(str1, list));
  7. System.out.println(huiwen(str2, list));
  8. }
  9. static boolean huiwen(String str,ArrayListIntegerStack list){
  10. int m=0;
  11. for(int i=0;i<str.length();i++){
  12. String a=String.valueOf(str.charAt(i));//取出字符串中的字符转化为字符串类型
  13. list.push(a);
  14. }
  15. for(int i=0;i<str.length()/2;i++){
  16. if(!list.pop().equals(String.valueOf(str.charAt(i))))
  17. return false;
  18. }
  19. return true;
  20. }
  21. }
  • 输出结果:

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

  • 关键代码:
  1. int count=1;
  2. while(!q2.isEmpty()||!q1.isEmpty()){
  3. if(!q1.isEmpty()){
  4. if(count==size)
  5. System.out.print(q1.poll());
  6. else if(q1.size()==2&&count==size-1)
  7. System.out.print(q1.poll()+" "+q1.poll());
  8. else{
  9. if(q1.size()==1){
  10. System.out.print(q1.poll()+" ");
  11. count++;
  12. }
  13. else{
  14. System.out.print(q1.poll()+" "+q1.poll()+" ");
  15. count=count+2;
  16. }
  17. }
  18. }
  19. if(!q2.isEmpty()){
  20. if(count==size)System.out.print(q2.poll());
  21. else
  22. System.out.print(q2.poll()+" ");
  23. count++;
  24. }
  25. }

注意题目要求输出的最后一个元素后面不能加空格。

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

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

  • 主要代码
  1. ArrayList<String> list=new ArrayList<String>();
  2. Set<String> strSet=new HashSet<String>();
  3. Set<String> set=new TreeSet<String>();
  4. while(true){
  5. String str=in.next();
  6. if(str.equals("!!!!!"))
  7. break;
  8. else list.add(str);
  9. }
  10. for (String e : list) {
  11. strSet.add(e);
  12. set.add(e);
  13. }
  14. System.out.println(strSet.size());
  15. if(strSet.size()<=10){
  16. for (String e : set)
  17. System.out.println(e);
  18. }
  19. else{
  20. int i=0;
  21. for (String e : set){
  22. i++;
  23. System.out.println(e);
  24. if(i==10)break;
  25. }
  26. }

5.1 实验总结

HashSet集合存放值互不相同的元素,TreeSet集合对集合中的元素进行排序。

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

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

6.1 伪代码

  1. 伪代码:
  2. Map<String, Integer> treemap = new TreeMap<String,Integer>();//创建TreeMap集合
  3. ArrayList<Map.Entry<String, Integer>> list=new ArrayList<Map.Entry<String, Integer>>(treemap.entrySet());//将treemap转化为线性表结构
  4. Collections.sort(list,new Comparator<Map.Entry<String, Integer>>(){});//按自定义的排序方式进行排序
  5. 关键代码:
  6. ArrayList<Map.Entry<String, Integer>> list=new ArrayList<Map.Entry<String, Integer>>(treemap.entrySet());
  7. Collections.sort(list,new Comparator<Map.Entry<String, Integer>>(){
  8. @Override
  9. public int compare(java.util.Map.Entry<String, Integer> o1, java.util.Map.Entry<String, Integer> o2) {
  10. if(o1.getValue()!=o2.getValue())return o2.getValue()-o1.getValue();
  11. return o1.getKey().compareTo(o2.getKey());
  12. }
  13. });

6.2 实验总结

因为TreeMap默认对键值排序,所以对值进行排序时,需要将Map集合转化为线性表结构,编写自定义的排序方式,进行排序。

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

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

7.2 使用集合类改进大作业





组员:陈凯欣,邱晓娴。本周项目的改动:实现了页面跳转,以及点击按钮实现数量的添加;目前还在研究如何将之前的代码和gui结合在一起,因为这一点还没解决,所以购物车虽然能做得出页面但是没办法完整实现商品数量的显示,另外也还在研究如何把登录的密码改为密文

  • 集合类在一开始设计的时候就有用到

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

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

3.1. 码云代码提交记录

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

3.2. PTA实验

编程(5-1, 5-2, 5-3(选做), 5-6)

实验总结已经在作业中体现,不用写。

201521123037 《Java程序设计》第7周学习总结的更多相关文章

  1. 20145213《Java程序设计》第九周学习总结

    20145213<Java程序设计>第九周学习总结 教材学习总结 "五一"假期过得太快,就像龙卷风.没有一点点防备,就与Java博客撞个满怀.在这个普天同庆的节日里,根 ...

  2. 20145213《Java程序设计》第二周学习总结

    20145213<Java程序设计>第二周学习总结 教材学习内容总结 本周娄老师给的任务是学习教材的第三章--基础语法.其实我觉得还蛮轻松的,因为在翻开厚重的书本,一股熟悉的气息扑面而来, ...

  3. 20145213《Java程序设计》第一周学习总结

    20145213<Java程序设计>第一周学习总结 教材学习内容总结 期待了一个寒假,终于见识到了神秘的娄老师和他的Java课.虽说算不上金风玉露一相逢,没有胜却人间无数也是情理之中,但娄 ...

  4. 21045308刘昊阳 《Java程序设计》第九周学习总结

    21045308刘昊阳 <Java程序设计>第九周学习总结 教材学习内容总结 第16章 整合数据库 16.1 JDBC入门 16.1.1 JDBC简介 数据库本身是个独立运行的应用程序 撰 ...

  5. 20145330孙文馨 《Java程序设计》第一周学习总结

    20145330孙文馨 <Java程序设计>第一周学习总结 教材学习内容总结 刚开始拿到这么厚一本书说没有压力是不可能的,开始从头看觉得很陌生进入不了状态,就稍微会有一点焦虑的感觉.于是就 ...

  6. 20145337 《Java程序设计》第九周学习总结

    20145337 <Java程序设计>第九周学习总结 教材学习内容总结 数据库本身是个独立运行的应用程序 撰写应用程序是利用通信协议对数据库进行指令交换,以进行数据的增删查找 JDBC可以 ...

  7. 20145337 《Java程序设计》第二周学习总结

    20145337 <Java程序设计>第二周学习总结 教材学习内容总结 Java可分基本类型与类类型: 基本类型分整数(short.int.long).字节(byte).浮点数(float ...

  8. 20145218《Java程序设计》第一周学习总结

    20145218 <Java程序设计>第一周学习总结 教材学习内容总结 今天下午看了Java学习的视频,感觉很是新奇,之前觉得Java学起来是艰难枯燥的,但通过第一章的学习觉得如果自己可以 ...

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

    20145224 <Java程序设计>第九周学习总结 第十六章 整合数据库 JDBC入门 ·数据库本身是个独立运行的应用程序 ·撰写应用程序是利用通信协议对数据库进行指令交换,以进行数据的 ...

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

    20145224陈颢文<Java程序设计>第二周学习总结 教材学习内容总结 一.类型.变量与运算符 1.类型 整数: 可细分为为short整数(占2字节),int整数(占4字节),long ...

随机推荐

  1. 解决百度BMR的spark集群开启slaves结点的问题

    前言 最近一直忙于和小伙伴倒腾着关于人工智能的比赛,一直都没有时间停下来更新更新我的博客.不过在这一个过程中,遇到了一些问题,我还是记录了下来,等到现在比较空闲了,于是一一整理出来写成博客.希望对于大 ...

  2. python学习===打印时间

    >>> import time >>> print(time.time()) 1501749158.9849465 >>> print(time. ...

  3. freemarker 集成 sitemesh 装饰html页面 shiro 标签

      guest标签:验证当前用户是否为"访客",即未认证(包含未记住)的用户: shiro标签:<shiro:guest></shiro:guest>  : ...

  4. include包含头文件的语句中,双引号和尖括号的区别

    include包含头文件的语句中,双引号和尖括号的区别   #include <>格式:引用标准库头文件,编译器从标准库目录开始搜索 #incluce ""格式:引用非 ...

  5. C#多线程的用法1-简单示例

    写在前面:阅读本系列文章即表示你已经知道什么是线程等理论知识,现在正想了解如何正确的使用线程进行编程工作. /// <summary> /// 单线程工作示例 /// </summa ...

  6. php创建多级目录完整封装类操作

    创建多级目录函数中调用创建指定下的指定文件的函数: public function create_dir($dir,$mode=0777) { return is_dir($dir) or ($thi ...

  7. 老司机和你深聊 Kubenertes 资源分配之 Request 和 Limit 解析

    欢迎大家前往腾讯云技术社区,获取更多腾讯海量技术实践干货哦~ 作者:腾讯云容器服务团队 Kubernetes是一个容器集群管理平台,Kubernetes需要统计整体平台的资源使用情况,合理地将资源分配 ...

  8. 转载_2012年的Android之旅:梦想、学习、坚持、自信、淡定

    原文地址:http://blog.csdn.net/luoshengyang/article/details/8452527 2012年的Android之旅:梦想.学习.坚持.自信.淡定.. ---- ...

  9. JavaScript面向对象(一)——JS OOP基础与JS 中This指向详解

      前  言 JRedu 学过程序语言的都知道,我们的程序语言进化是从"面向机器".到"面向过程".再到"面向对象"一步步的发展而来.类似于 ...

  10. 设计一个程序能够将某一个目录下面的所有文件名打印出来---File类的使用

    ,设计一个程序能够将某一个目录下面的所有文件名打印出来 运用到的方法有:返回一个字符串数组,这些字符串指定此抽象路径名表示的目录中的文件和目录:list()           测试此抽象路径名表示的 ...