2017-09-09学习记录
今天具体看了下第八章和第十一章;第九章的接口很多东西还没有搞明白,所以还是明天花时间搞定一下;下面是今天的知识:
第八章:多态
前几章我发现,继承允许将对象作为对象本身和作为对象的基类来运行;在这种情况下,可以实现用一个基类作为函数的参数,让这个函数调用这个基类的各种子类;
而在这里,又要用动态绑定知识了,静态绑定指的是在编译器刚编译时就绑定了的函数,这种函数的参数,运行结果早就已经固定了,一般这种是static函数和final函数;而动态绑定则是只有在运行时才知道具体要运行的代码,根据传入参数的类型来决定调用那些代码;
多态就是这样,根据作为参数传入的基类引用绑定的具体子类对象的类型,判断调用那个子类中具体的函数;把子类对象用基类引用传入函数中时,在函数中调用基类方法时,调用的是这个子类中已经重写过的方法;多态就是借用这个特性,用基类引用作为参数,实现在不知道子类类型的情况下调用子类的代码;
说起前面的向上转型,基类和子类的关系就是一种子类包含基类的关系,子类》=基类;所以向上转型就是指去掉子类中那些和基类不重叠的地方,把子类当做一个方法一样的基类来使用,相对于来说是减小了子类的范围域;
说到向上转型就有向下转型,这里指的是对那些已经作为基类引用的子类对象,对这个基类引用进行子类引用的强转型,这里编译器会自动判断是否转型成功;转型成功后还可以调用那些扩展的方法;类似于下面的代码;
向上转型和向下扩展上面moreuseful对象绑定在useful引用上,下面又对useful引用进行扩展的强转型;这里编译器没有报错,说明这种方法是可行的;
基类被复写的方法之间是相互独立的;在子类的构造器中,最好不要用被复写的方法,这样的话在初始化子类时,父类构造器被调用,这个时候父类中的这个方法也会用到多态属性,调用子类已经复写过的方法;所以一般用简单的语句来编写构造方法;尽量不要在构造器中调用被复写的方法;
第十一章:持有对象(容器)
容器指的是存储数据的对象,这个和数组不同,容器可以根据数据的大小自动的生成对应的空间;而容器可以存储入任何对象;为了防止一个容器存入多种对象,用泛型来标记存入对象的类型;容器也是对象;
泛型的语法:collection<Shape> s = new collection <.Shape > ();Shape代表存入其中的对象;
容器的父类为collection;其余的容器都是collection的子类;
容器分成两大类:1.独立元素队列,像是一维序列;List,ArrayList,LinkedList,set,Hashset……等很多类型,其中每个类型有自己的长处和短处; 2.map类型,由键-值对组成的队列,其中键是不能重复的,值可以由任何对象组成,主要是一个相对的关系;
下面就先解释collection:
往collection中插入数据:1.add方法;2.collections.addAll(collection,array);3.arrays.asList(Array);返回一个list<T>对象;4.collecition.addAll( collection <T> s);用collection对象作为参数来初始化;上面四种方法,其中先创建一个空collection,再用2,3两种方法添加则是最快的;(有一点:arrays.asList返回的对象本质上是数组,所有在进行增删操作时会提示不能被resize)
容器打印直接调用print打印即可;
迭代器:iterator对象;每一个collection中都有iterator()方法,返回的是一个iterator对象;该对象内有hasNext方法,next,nextIndex方法;可以用foreach来循环输出所有的数据;我个人感觉,内部是有一个变量next,初始化为o,nextIndex方法返回这个变量,调用next方法时返回该下标的对象,然后next++;remove方法除去的对象的下标是这个变量-1;至于在list中的ListIterator中的previous方法返回的是下标为变量-1的对象;
下面介绍容器的子类:
1.List<T>:这个list的是基于collection的容器,它分为ArrayList和LinkedList;内部的迭代器就是上文的listIterator;它相对于collection添加了一些方法,方法和功能如下:
list方法上面的方法中,前两个contains是判断该list中是否存在对象,1的参数为对象引用,2的参数为对象数组;3根据引用去除list中的对象;4用引用找出在list中的下标;5.equals方法和1一样;6.sublist方法是把list中的数据根据下标ab取出来返回一个对象数组,【a,b);7.isEmpty判断是否为空;8.toAtrray则将list变成数组;
在list中分成ArrayList和LinkedList,就好像数组和链表的区别,arrayList倾向于随机读取数据,LinkedList则倾向于增删数据;各有各的擅长部分;下面是LinkedList的几个方法;
linkedList本质上是一个双向链表;内部有addFirst();addLast;getFirst;getLast;removeFirst;removeLast;另外,1,remove和poll方法去除首端对象并返回;2.peek和element返回首端对象但不去除;3.offer和add在尾端添加对象;
这些函数也为LinkedList添加了扩展的机会。Stack(栈LIFO)Queue(队列FIFO)都是由LinkedList衍生而来的;尤其是Queue,新添加的几个方法都是为Queue而存在的;
2.set:说完了list,说set,set是一个不不保存重复对象的容器,它的作用主要是用来测试归属性,即该对象是否存在于本容器中;set用contains来测试归属性;用add来添加对象;用remove来清除对象;
set的分类:1.Hashset:高速存储和查验;2.TreeSet:按顺序排布数据;3,linkedHashSet:按照存储的顺序排布且具有高速存储查验的set;
3.map:主要是键值对;对应python中的dict;1.put添加数据,2.keySet()返回键的set对象;3.values()返回值的collection对象;4.get(键)查找值;5.用remove(键)删除键值对;
foreach可以用于任意的collection,因为在collection内部有iterator类;这个代表foreach可以对iterator类进行便历;只要对象中有这种类型的方法,它就可以通过iterator类来遍历容器中所有的对象;
上面就是今天的知识,以后有时间再修改补充;