教材学习内容总结

第十五章 泛型与集合框架

泛型

1.泛型类声明:
class People<E>
其中People是泛型类的名称,E是其中的泛型
2.泛型的重要目的是可以建立具有类型安全的数据结构,如链表、散列表等数据结构,而且在使用这些泛型类建立的数据结构时,不必进行强制类型转换,即不要求进行运行时的类型检查。

链表

1.链表示意图

2.LinkedList泛型类
java.util 包中的 LinkedList泛型类创建的对象以链表结构储存数据,习惯上称LinkedList类创建的对象为链表对象
LinkedList<String> mylist=new LinkedList<String>();
3.常用方法:
public boolean add<E element>向链表的指定位置添加一个新的结点,该结点中的数据是参数element指定的数据
public void add(int index, E element)向链表的指定位置添加一个新的结点,该结点中的数据是参数element指定的数据
public void clear()删除链表的所有结点,使当前链表成为空链表
public E remove(int index)删除指定位置上的结点
public boolean remove(E element)删除首次出现含有数据element的结点
public E get(int index)得到链表中指定位置处结点中的数据
public int indexOf(E element)返回含有数据element的结点在链表中首次出现的位置,如果链表中无此结点则返回-1
public int lastIndexOf(E element)返回含有数据element的结点在链表中最后出现的位置,如果链表中无此结点则返回-1
public E set(int index,E element)将当前链表index位置结点中的数据替换为参数element指定的数据,并返回被替换的数据
public int size()返回链表的长度,即结点的个数
public boolean contains(Object element)判断链表中是否有结点含有数据element。
public void addFirst(E element)向链表的头添加新结点,该结点中的数据是参数element指定的数据
public void addLast(E element)向链表的末尾添加新结点,该结点中的数据是参数element指定的数据
public E getFirst()得到链表中第一个结点中的数据
public E getLast()得到链表中最后一个结点中的数据
public E removeFirst()删除第一个结点,并返回这个结点中的数据
public E removeLast()删除最后一个结点,并返回这个结点中的数据
public Object clone()得到当前链表的一个克隆链表,该克隆链表中结点数据的改变不会影响到当前链表中结点的数据,反之亦然
4.遍历链表
链表对象可以使用iterator()方法获取一个Iterator对象,该对象是针对当前链表的迭代器
5.排序与查找
public static sort(List<E>list)该方法可以将list中的元素按顺序排序。
int binarySearch(List<T>list,T key,CompareTo<T>c)使用析半法查找list是否含有和参数key相等的元素,如果key与链表中的某个元素相等,方法返回和key相等的元素在链表中的索引位置(链表的索引位置从0开始),否则返回-1。
6.洗牌与旋转
public static void shuffle(List<E>list)将list中的元素按洗牌算法重新随机排序
static void rotate(List<E>list,int distance)旋转链表中的数据
public static void reverse(List<E>list)翻转list中的数据

堆栈

1.堆栈只能在一端进行输入或输出数据的操作。堆栈把第一个放入该堆栈的数据放在最底下,而把后续放入的数据放在已有的数据的顶上。
2.方法:
public E push(E item)实现压栈操作(向堆栈中输入数据)
public E pop()实现弹栈操作(从堆栈中输出数据)
public boolean empty()判断堆栈是否还有数据
public E peek()获取堆栈顶端的数据,但不能删除该数据
public int search(Object data)获取数据在堆栈中的位置

散列映射

1.HashMap<K,V>泛型类创建的对象称作散列映射
HashMap<String,Student> hashtable=HashSet<String,Student>();
2.常用方法:
public void clear清空散列映射
public Object clone()返回当前散列映射的一个克隆
public V get(Object key)返回散列映射中使用key做键的键/值对中的值
public V remove(Object key)删除散列映射中键为参数指定的键/值对,并返回键对应的值。
public int size()返回散列映射大小,即散列映射中键/值对的数目。

树集

1.TreeSet泛型类
TreeSet<E>类是实现Set<E>接口的类,它的大部分方法都是接口方法的实现。
2.TreeSet类的常用方法
public boolean add(E o)向树集添加结点,结点中的数据由参数指定,添加成功返回true,否则返回false
public void clear()删除树集中的所有结点
public void contains(Object o)如果树集中有包含参数指定的对象,则返回true,否则返回false
public E first()返回树集中的第一个结点中的数据
public E last()返回树集中的最后一个结点中的数据
public boolean isEmpty()判断是否是空树集,如果树集不含任何结点,则返回true
public boolean remove(Object o)删除树集中的存储参数指定的对象的最小结点,删除成功返回true,否则返回false
public int size()返回树集中结点的数目

代码托管(https://gitee.com/Lyh20175309/java-besti-is-lyh/tree/master/jcdm)

学习心得

是真的难,发现自己前面基础打的不牢固了

转载于:https://www.cnblogs.com/20175309lyh/p/10745592.html

《JAVA程序设计》第八周学习总结相关推荐

  1. 20155227 2016-2017-2 《Java程序设计》第九周学习总结

    20155227 2016-2017-2 <Java程序设计>第九周学习总结 教材学习内容总结 JDBC简介 JDBC全名Java DataBase Connectivity,是java联 ...

  2. 20155303 2016-2017-2 《Java程序设计》第二周学习总结

    20155303 2016-2017-2 <Java程序设计>第二周学习总结 教材学习内容总结 『注意』 "//"为单行批注符: "/*"与&quo ...

  3. 20175227张雪莹 2018-2019-2 《Java程序设计》第九周学习总结

    20175227张雪莹 2018-2019-2 <Java程序设计>第九周学习总结 教材学习内容总结 第十一章 JDBC数据库操作 MySQL数据库管理系统 下载安装MySQL 若下载的是 ...

  4. 20155305乔磊2016-2017-2《Java程序设计》第九周学习总结

    20155305 2016-2017-2 <Java程序设计>第九周学习总结 教材学习内容总结 JDBC入门 JDBC简介 1.JDBC是java联机数据库的标准规范,它定义了一组标准类与 ...

  5. 20175317 《Java程序设计》第一周学习总结

    20175317 <Java程序设计>第一周学习总结 教材学习内容总结 本周学习了Java大致的开发步骤,完成了课件自带的习题. 学习了在windows与Linux系统下不同的编译方法,掌 ...

  6. 20172318 2016-2017-2 《Java程序设计》第一周学习总结

    20172318 2016-2017-2 <Java程序设计>第一周学习总结 教材学习内容总结 在教材中基本明白了计算机系统的运行方式,了解了对于高级语言是使用是掌握好编程的关键,掌握了一 ...

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

    20175208 2018-2019-2 <Java程序设计>第九周学习总结 一.教材学习内容总结: 第11章 JDBC与MySQL数据库 MySQL数据库管理系统 MySQL数据库管理系 ...

  8. 20175204 张湲祯 2018-2019-2《Java程序设计》第九周学习总结

    20175204 张湲祯 2018-2019-2<Java程序设计>第九周学习总结 教材学习内容总结 -第十一章JDBC和MySQL数据库要点: 1.下载MySQL和客户端管理工具navi ...

  9. 20155313 2016-2017-2 《Java程序设计》第二周学习总结

    20155313 2016-2017-2 <Java程序设计>第二周学习总结 教材学习内容总结 1.1 基本类型 整数:可细分为short整数(占2字节).int整数(占4字节)与long ...

  10. 20155226 2016-2017-2 《Java程序设计》第一周学习总结

    20155226 2006-2007-2 <Java程序设计>第一周学习总结 教材学习内容总结 第一周主要学习了一二章的内容,也浏览了剩余章节,以下是本周主要学习内容总结 1.首先了解了[ ...

最新文章

  1. enumerate在python中的意思_Python中enumerate用法详解
  2. 7-4 找到共同的选修课-hebust (10 分)
  3. 程序员爱护自己身体的几点建议
  4. MySQL单机版Recycle Bin回收站功能
  5. Java DataInputStream readBoolean()方法(带示例)
  6. (三)Appium-desktop 打包
  7. 自己动手美化博客园个人博客
  8. 黑丝YYDS,通过五十行代码分分钟下载上万张黑丝小姐姐纯欲高清图!(宅男福利)
  9. PHP直播源码,直播系统源代码功能有哪些?
  10. python3爬虫(2):使用Selenium爬取百度文库word文章
  11. 让Fireball CodeEditor控件支持中文
  12. 迪士尼无限3.0连接服务器,迪士尼无限3period;0BUG问题解决 | 手游网游页游攻略大全...
  13. 论文阅读《A Large Dataset to Train Convolutional Networks for Disparity, Optical Flow, and Scene Flow Es》
  14. shell技巧4 - nm命令解决AppStore2.5.2被拒问题
  15. php开发自己的composer包
  16. 日本人为什么不吃鲤鱼
  17. java中线程控制方法的说法正确的是_在java程序中,下列关于线程的说法错误的时()...
  18. 汽车维修管理系统汽车维修管理系统采用B / S架构,主要使用Java技术进行开发,结合最新流行的java和mysql的SSM框架技术。
  19. 评测3款高颜值的azw3阅读器(ios手机适用)
  20. 狗宝宝取名大全2018款之提前为宝宝取名好吗

热门文章

  1. elasticsearch常见报错总结
  2. Qt Creator创建项目
  3. java jar包和war包_java中jar包和war包之间有什么区别
  4. php 获取企业号用户,微信企业号 获取用户信息(示例代码)
  5. PhotoGun中文版
  6. 【面试题】hashCode() 和 equals() 之间的关系
  7. 共享打印机,解决驱动检测失败无法连接共享打印机问题
  8. oracle的那些事
  9. poj 3040 Allowance
  10. C#窗体控件-组合框控件ComboBox