黑马程序员技术交流社区
标题:
【石家庄校区】Java的上车了
[打印本页]
作者:
黑马7期班长
时间:
2018-4-14 17:57
标题:
【石家庄校区】Java的上车了
本帖最后由 小石姐姐 于 2018-4-20 09:42 编辑
Java的上车了-知识点大全
Object对象是所有对象的父类,并定义了所有对象公共的属性和方法,toString(),将对象转换成字符串getClass(),获取该对象的类gethashCode(),获取对象的hashCode,如定义Student对象时,可以重写他的任何方法,toString(),打印打印学生的属性,进行调试比较方便,equals(),当重写可以利用两个对象的属性不同来比较对象是否相同。
System对象,currentTimeMillis()获取当前时间到1970/1/1,0:0的时间(当测试程序运行时间时可用到)
System.arrayCopy([] src,int srcIndex,[] dest,destIndex, int count);把数组复制到另一个数组,从指定索引和几个元素
Date对象
时间类的对象,包含时间的所有方法。
构造方法Date d = new Date();//空参数 表示当前时间 返回
属性;d.getTime(); //以指定格式返回时间
d.setTime(long l);//设置时间 从1970+long的毫秒数
SimpleDateFormat
格式化时间,用来格式化日期的类
构造方法
SimpleDateFormar sdf = new SimpleDateFromat("yyyy-MM-dd");//四个小姨子,两个大MM,两个小dd
方法:format(); //将日期转换成String
parse(String s) //将日期字符串转换成Date对象
Collection
所有集合的接口,包含了所有集合的共性.
体系结构----
Collection
List
ArrayList--有索引,有序,可存放引用数据类型
boolean IsEmpty(); 判断是否为空
boolean clear();
boolean contains();
LinkedList-链表
Set
hashSet--无索引,无序,可存放引用数据类型
迭代器 Itearotor
Iterator接口迭代器 实现对Collection 进行遍历 Iterator it = Collection.iterator(); 通过集合对象获取的迭代器,一对一关系啊
迭代器实际上就是集合的一个副本,当操作迭代器是再操作数组就会报出并发修改异常,意思就是原来的集合跟迭代器不同了。并发就是两个线程同时访问一个集合
ListIteator用来专门迭代List的迭代器,中间可修改,删除元素
泛型<E>
指定容器存放指定的数据类型,或者bin文件操作指定的类型,运行时就会消失,如果不添加泛型,可能会出现编译错误。把数据类型提前定义,避免出现类型转换的错误。
ArrayList<String> arr = new ArrayList<>();
foreach 高效循环
for(object obj :容器){
//可以操作每一个obj
}
linkedList链表操作快,查询慢
,fisrt地址值,next地址值
堆栈
堆,先进先出,(排队)
栈 压栈 先进后出 (弹夹)
遍历集合方式:
1.用ArrayList.toArray(); 返回值为Object类型的数组
2.用iterator中的hasNext();如果有就让他获取下一个
3.用最原始的方法for循环遍历
数据结构
数组的特点:
只能放相同的元素
查找快增删慢
如果想要得到数组的某一个元素,直接根据索引就行。
链表的特点
1.就是把数据链到一起,一个元素包括 当前的地址值 -值 - 下一个的地址值 (最后一个没有下一个的地址值)
2.操作快,查询慢
如果想要查询一个数据,会一直查询到最后
但是添加或者删除,添加把前一个的下一个地址值改为你添加进来的地址值,把你添加进来的地址值改为下一个的地址值
队列和栈
队列 :先进先出 ---排队
栈 :先进后出 ---弹夹
List接口 有整数的索引,顺序排列,顺序可重复
ArrayList 底层为数组结构 查询快,修改慢
LinkedList 链表 查询慢修改快 , 根据不同需求使用不同列表
当创建List接口指向子类对象 ArrayList 或者是LinkedList
都会用List<E> lis = new ArrayList();
当操作学生对象时会用到ArrayList
当查询
编译后泛型就不存在了
泛型定在在类中
调用时,分为上界和下届
声明泛型
静态方法中定义的泛型只能自己使用
如果接口中定义泛型 实现类必须
非静态方法定义的泛型
<? extends 父类/接口> 下届 最高不能超过父类的泛型
<? surper 子类/接口> 上界 最低不能低于子类的泛型
HashSet
跟ArrayList同级别,并同时父接口为Set,同是Collection的子接口
无参构造
HashSet<E> hs = new HashSet<E>();
注意:如果是父接口引用指向子类对象,就无法使用子类的特殊方法
特点:Set没有顺序,不允许重复
在获取hashcode时不重写就默认就使用Object.hashCode();
如果父类重写了hashCode子类默认调用 一般用的时候都写成同样的hashcode();
set中判断是否重复机制:首先先判断他的hashcode值,然后在判断地址值,添加对象时如果想判断两个对象是否相当,必须重写toString()方法
pubilc String toString(){
}
重写对象equals方法
重写hashCode方法(健壮性)
public int equals( Object obj){
//首先判断两个元素地址值是否相同,如果相同直接返回True
if(this == obj){
return true;
}
//健壮性,如果他的类型不相同也不进行判断
if(this.getClass() != obj.getClass()){
return false;
}
//判断他的hashCode是否相等
if(this.hashCode != obj.hashCode){
if(!this.getName(obj.getName)){//?是否多余
//如果他的hasCode不相等证明对象值不相等
return false;
}
}
}
Collections 工具类
Collection 跟Collections 的区别
collection 是所有集合的共性,是一个接口 包含List 和 set
collection 是工具类,用来操作List
具体静态方法
` binarySearch(List list, T key)//二分查找 从中间查找 只能查找有顺序的List 不能查找set
copy(List dest, List src);复制集合?//覆盖目标集合,但是目标List的size必须大于等于原来集合size()
fill(List lis,Object obj);将List中的所有元素替换成obj
shuffle(List list);//随机打乱顺序
sort(List<T> list) //将元素按自然规律排序
swap(List<?> list, int i, int j) lis.swap(另一个list,lis的索引,另一个lis的索引)
演示斗地主发牌
是否能把牌定义成对象//不能
Map<K,V>
是一个接口,储存的值为一对一关系的值。双列集合,key value ,键不能重复,键是无序的,一个键只能映射一个值
Map跟Collection 的区别
Collection 单身汉集合,ArrayList有序列有索引,Set无索引无序列
put()添加映射关系
Map的映射 如果键相等就直接覆盖,返回覆盖前的值
containKey()//判断键是否存在
containValue()//判断值是否存在
remove(Key)//返回对应Key的值然后在删除
整理set
不允许重复,并且没有索引
hashSet实现Set
可以用迭代器遍历
整理Map
hashMap实现Map
不允许重复,双列存储格式
遍历方式
增强for(根据键查找它对应的值)map.get(K);
entrySet();
entry是Map的内部类、
使用方式
Set<Map.entry<K,V>> set = map.entry();
for(Map.entry<K,V> entry : set){
k.getKey();
v.get value();//内部类的特有方法
syso(k+v);//
}
多重嵌套Map<String,Map<Integer,String>> map = new HashMap<>();
分析
1,先获取map的键
Set<String>set = map.keySet();
for(String str : set){
String s = str;
syso("就业班"+str)
Map<Integer,String> map2 = map.get(str);
//依次类推
}
递归
5*5
斐波那契列数
result = (n-1)+(n-2);
异常
Throwable(最顶层)
Error 系统不能处理 比较严重的错误
Exception 系统可以处理的异常
编译时异常
当不符合编译器规范为编译时异常
运行时异常
当运行时出现的异常
jvm处理异常方式
如果我们没有处理异常,jvm会终止我的程序,然后把异常类型,原因输出在控制台
语法规则
try{
}catch(){//调用catch方法创建错误对象
处理异常
}
fanily{
}
Thorwable
e.getMessage
e.toString();
e.PrintStackTrace;
finally 目的就是程序的收尾,释放资源 一定会执行
如何定义异常
异常也是一个对象
继承超类
重写有参数无参数构造
欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/)
黑马程序员IT技术论坛 X3.2