20175316盛茂淞 2018-2019-2 《Java程序设计》第8周学习总结

20175316盛茂淞 2018-2019-2 《Java程序设计》第8周学习总结

教材学习内容总结

第十五章

  • 泛型
    -- 主要目的是可以建立具有类型安全的集合框架,如链表、散列映射等数据结构
    -- 泛型类声明
    可以使用class 名称<泛型列表>声明一个类,为了和普通的类有所区别,这样声明的类称作泛型类,没有指定E是何种类型的数据,它可以是任何对象或接口,但不能是基本类型数据
    -- 使用泛型类声明对象
    泛型类声明和创建对象时,类名后多了一对“<>”,而且必须要用具体的类型替换“<>”中的泛型
  • 链表
    -- 链表是由若干个称作节点的对象组成的一种数据结构,每个节点含有一个数据和下一个节点的引用
    -- LinkedList<E>泛型类
    LinkedList泛型类创建的对象以链表结构存储数据,习惯上称LinkedList类创建的对象为链表对象
    LinkedList<String> mylist=new LinkedList<String>();创建一个空双链表
    add(E obj) 向链表依次增加节点
    -- 常用方法
    ?LinkedList泛型类实现Lis泛型接口中的一些常用方法
    ?public boolean add(E element) 向链表末尾添加一个新的节点,该节点中的数据是参数elememt指定的数据
    ?public void add(int index ,E element) 向链表的指定位置添加一个新的节点,该节点中的数据是参数elememt指定的数据
    ?public void clear() 删除链表的所有节点,使当前链表成为空链表
    ?public E remove(int index)删除指定位置上的节点
    ?public boolean remove(E element) 删除首次出现含有数据elemen的节点
    ?public E get(int index) 得到链表中指定位置处节点中的数据
    ?LinkedList泛型类本身新增加的一些常用方法
    ?public void addFirst(E element) 向链表的头添加新节点,该节点中的数据是参数elememt指定的数据
    ?public void addLast(E element)向链表的末尾添加新节点,该节点中的数据是参数elememt指定的数据
    ?public E getFirst() 得到链表中第一个节点中的数据
    ?public E getLast()得到链表中最后一个节点中的数据
    ?public E removeFirst() 删除第一个节点,并返回这个节点中的数据
    -- 遍历链表
    ?当用户需要遍历集合中的对象时,应当使用该集合提供的迭代器,而不是让集合本身来遍历其中的对象
    ?链表对象可以使用iterator()方法获取一个Iterator对象,该对象就是针对当前链表的迭代器
    -- 排序与查找
    ?Collections类提供的用于排序和查找的类方法如下:
    ?public static sort(List<E> list): 该方法可以将list中的元素升序排列
    ?int binarySearch(List<T> list, T key,CompareTo<T> c):使用折半法查找list是否含有和参数key相等的元素,如果key链表中某个元素相等,方法返回和key相等的元素在链表中的索引位置(链表的索引位置从0考试),否则返回-1
    -- 洗牌与旋转
    ?Collections类还提供了将链表中的数据重新随机排列的类方法以及旋转链表中数据的类方法
    ?public static void shuffle(List<E> list) 将list中的数据按洗牌算法重新随机排列
    ?static void rotate(List<E> list, int distance) 旋转链表中的数据
    ?public static void reverse(List<E> list) 翻转list中的数据
    -- 堆栈
    ?堆栈是一种“后进先出”的数据结构,只能在一端进行输入或输出数据的操作
    ?Stack泛型类创建一个堆栈对象,堆栈对象常用方法:
    ?public E push(E item);实现压栈操作
    ?public E pop();实现弹栈操作
    ?public boolean empty();判断堆栈是否还有数据
    ?public E peek();获取堆栈顶端的数据,但不删除该数据
    ?public int search(Object data);获取数据在堆栈中的位置
    -- 散列映射
    ?HashMap<K,V>泛型类
    ?HashMap<K,V>对象采用散列表这种数据结构存储数据,习惯上称HashMap<K,V>对象为散列映射
    ?相关方法:
    public V put(K key,V value)将键/值对数据存放到散列映射中,该方法同时返回键所对应的值
    ?常用方法:
    ?public void clear() 清空散列映射
    ?public Object clone()返回当前散列映射的一个克隆
    ?public boolean containsKey(Object key) 如果散列映射有“键/值”对使用了参数指定的键,方法返回true,否则返回false
    ?public boolean containsValue(Object value) 如果散列映射有“键/值”对的值是参数指定的值
    ?public V get(Object key)返回散列映射中使用key做键的“键/值”对中的值
    ?public boolean isEmpty() 如果散列映射不含任何“键/值”对,方法返回true,否则返回false
    ?public V remove(Object key) 删除散列映射中键为参数指定的“键/值”对,并返回键对应的值
    ?public int size() 返回散列映射的大小,即散列映射中“键/值”对的数目
    -- 树集
    ?TreeSet<E>泛型类
    ?TreeSet类创建的对象称作树集
    ?TreeSet<String> mytree=new TreeSe<String>();
    ?mytree.add("boy"); 使用add方法为树集添加节点

    ?TreeSet类的常用方法
    ?public boolean add(E o) 向树集添加加节点
    ?public void clear() 删除树集中的所有节点
    ?public void contains(Object o) 如果树集中有包含参数指定的对象,该方法返回true,否则返回false
    ?public E first() 返回树集中的第一个节点中的数据(最小的节点)
    ?public E last() 返回最后一个节点中的数据(最大的节点)
    ?public isEmpty() 判断是否是空树集,如果树集不含任何节点,该方法返回true
    ?public boolean remove(Object o)删除树集中的存储参数指定的对象的最小节点
    ?public int size() 返回树集中节点的数目

原文地址:https://www.cnblogs.com/sms369/p/10744922.html

时间: 2024-10-08 21:59:35

20175316盛茂淞 2018-2019-2 《Java程序设计》第8周学习总结的相关文章

20175316盛茂淞 2018-2019-2 《Java程序设计》第5周学习总结

20175316盛茂淞 2018-2019-2 <Java程序设计>第5周学习总结 教材学习内容总结 第六章 接口与实现. 何谓接口 接口:书上没有明确地给出接口的定义,我理解的接口就是一段程序中可能有很多类会有共同的行为,但这些类本身并不具有任何关系,如果使用继承的话程序架构会不合理,所以使用统一的接口表示这些类具有共同的行为 interface 可定义行为,例如: public interface Swimmer{ public abstract void swim(); } implem

20175316盛茂淞与20175329许钰玮结队合作

20175316盛茂淞与20175329许钰玮结队合作 一.团队合作意义 团队合作指的是一群有能力,有信念的人在特定的团队中,为了一个共同的目标相互支持合作奋斗的过程.它可以调动团队成员的所有资源和才智,并且会自动地驱除所有不和谐和不公正现象,同时会给予那些诚心.大公无私的奉献者适当的回[1]报.如果团队合作是出于自觉自愿时,它必将会产生一股强大而且持久的力量. 二.团队合作的表现力 (1)成员密切合作,配合默契,共同决策和与他人协商. (2)决策之前听取相关意见,把手头的任务和别人的意见联系起

2019-2020-2 20175316盛茂淞《网络对抗技术》Exp3 免杀原理与实践

2019-2020-2 20175316盛茂淞<网络对抗技术>Exp3 免杀原理与实践 一.实验目标 熟悉后门的概念 使用netcat实现win,linux之间的后门连接 掌握meterpreter的应用 了解MSF POST 模块的应用 学会win,linux的后门启动方式 二.基础问题回答 1.杀软是如何检测出恶意代码的? 基于特征码的检测(需要定期更新病毒库) 启发式恶意软件检测(实时监控,开销较大) 基于行为的恶意软件检测(如API监控) 2.免杀是做什么? 通过伪装,加解密,对she

20155336 2016-2017-2《JAVA程序设计》第二周学习总结

20155336 2016-2017-2 <JAVA 程序设计>第二周学习总结 教材学习内容 1: GIT版本检测 2: JAVA中基本类型 整数 字节 浮点数 字符 布尔(▲) 通过API可以得知各个类型可存储的数值范围 public class Range {public static void main(String[] args){ //byte.short.int.long的范围 System.out.printf("%d~%d%n", Byte.MIN_VALU

20145201 《Java程序设计》第一周学习总结

# 20145201 <Java程序设计>第一周学习总结 ## 教材学习内容总结 万事开头难,终于开始学习了Java.寒假的时候看到老师的要求确实有点慌,但是这周翻开书,从书本知识第一行学起,发现并不是自己想想中那么难,只要一步一个脚印,每周有自己的计划,并按照计划按部就班的完成,最后一定会拥有自己的小成果的. 1.1Java不只是语言 Java经过多年的版本更新后,最新的版本是Java SE8. 在java发展的过程中,它的应用领域越来越广,根据不同级别的应用开发区分了不同的应用版本,最终j

20145326蔡馨熠《Java程序设计》第一周学习总结

20145326蔡馨熠 <Java程序设计>第一周学习总结 教材学习内容总结 转眼间新的一学期终于开始了!为什么我这么期待呢?因为这学期可以上娄嘉鹏老师的java程序设计课,我不是什么电脑天才,之前c语言学得也不是特别好.可我就是对hdl和java特别感兴趣(之前在我的问卷调查报告里面提到过),并且寒假的时候在家里也预习了一部分java知识.第一周要求学习两个章节并作心得体会,虽然我早已看过前两章的知识,不过为了进一步巩固,我还是用了星期六一天的时间把第一章和第二章的知识从头到尾仔仔细细的看了

20145224-陈颢文 《Java程序设计》第一周学习总结

20145224 <Java程序设计>第一周学习总结 教材学习内容总结 通过第一周的学习让我对Java有了个初步的了解,知道了Java分为Java SE.Java EE.Java ME三大平台,其中Java SE是基础.Java的一大特点是它可以跨平台,而JVM对Java的跨平台提供了支持,它就类似于一个虚拟机,只要在当前平台安装了相应的JVM,Java程序就有了可以在此平台上运行的基础啦.JRE是Java的执行环境,在安装了JRE的计算机上就可以运行Java的程序了,当然光是可以跑代码对于程

20155335 俞昆 2016-2017-2 《Java程序设计》第九周学习总结

学号 2016-2017-2 <Java程序设计>第九周学习总结 ##JDBC入门 在正式介绍JDBC前,已知JDBC是用来执行SQL的解决方案,开发人员使用JDBC的标准接口,开发人员不需接触底层数据库驱动程序的差异性. 本章,我们需要了解JDBC与API使用和概念,我们先要认识应用程序如何与数据库进行沟通,数据库本身是一种独立运行的应用程旭,程序员撰写的应用程序是利用通信协议对数据库进行指令交换,以进行数据的增加删除以及查找. 通常应用程序会利用一组专门与数据库进行通信协议的链接库,以简化

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

20145326<Java程序设计>第二周学习总结 教材学习内容总结 本周学习教材第三章,本章主要讲述了java语言中的一些基础语法,java是个支持面向对象的程序语言,但在正式进入面向对象支持语法的探讨前,对于类型.变量.运算符.流程控制等,这些各种程序语言都会有的基本语法元素,还是要有一定的基础.虽然各种程序语言都有这些基本语法元素,但千万别因此而轻忽它们,因为各种程序语言都有其诞生的宗旨与演化过程,对这些基本语法元素,也就会有其独有的特性. 1. 类型 在java的世界中,并非每个东西都