JAVA学习第五周总结

本周继上周的常用类之后又学习一些,本周重点学习异常和集合类,对于集合都是要多用多实践,知识点庞多,但是有一定的规律,只要对Collection这个老大的方法熟知,下面的一些子类可游刃有余,还有HashMap这个面试重点要掌握。
第一天常用类1.Runtime类,获取当前jvm虚拟机运行时的一些数据,totalMemory()、freeMemory()、maxMemory()。2.System类,奔雷提供有关于系统的一些属性信息和一些其他的方法,gc()垃圾回收、currentTimeMillis()获取当前系统时间的毫秒数、getProperties()获取当前系统相关的一些属性信息,如操作系统版本、jdk版本等等。3.Date类,获取当前的系统时间,SimpleDateFormat日期格式化类.4.Calendar类
,此类不能直接new对象。
第二天异常try,catch,finally,throw,throws.其中try不能单独出现,必须结合catch和finally来使用,将有可能出现异常的放进try中。catch用来捕获异常并进行处理,也不能单独出现
必须和try一起使用。finally也必须和try一起使用,表示不管是否出现异常都会执行的代码块。throw用来抛出异常,throw后面加异常对象,一次只能抛出一个。throws表示声明异常
,直接跟在方法的参数列表后面,可以声明多个异常,它们之间用逗号隔开就可以。自定义异常,已存在的异常不能满足我们的需求,我们可以自定义,自定义时继承Throwable类,或者Exception类,RuntimeException类,继承之后编写有参数String类型的构造方法。
第三天集合,将集合的家族关系要熟记于心,先讲了List中的ArrayList,此集合线程不安全,有下标,访问和查询效率高,但是删除和修改效率低,因为涉及到移动元素,复制数组这些。当我们第一次执行add方法的时候,将数组的长度赋值为10,当添加不够的情况下,扩容为原来的1.5倍。Vector类,线程安全但是效率低,当我们直接调用无参构造方法的时候直接初始化一个长度为10的数组,扩容的话扩为原来的两倍。LinkedList类,是基于双向链表的,它是非线程安全的,增删和修改快,但是效率低,没有初始化大小,在遍历LinkedList结构的时候,不要使用普通for循环来获取元素,它中的get方法是将当前的表结构中的元素一分为二的进行查找。遍历的三种方式,普通for循环,增强for循环,迭代器Iterator。
第四天先讲了泛型,用它来规定我们集合中元素的类型,可以作用于类、接口、形参等场合,通常使用T、E、K、V。接口interfanceA,表示当前接口的实现类可以传入
一个具体的类型,来实现不同类实现同一个接口,达到不同的结果。类中classA,表示当前类创建实例可以传入一个具体的对象,这个对象也可以被本类中的方法所使用达到创建同一个类的不同的实例,来实现不同的效果。形参 void method(List<?> list){},表示当前方法所支持的参数首先是一个List集合,这种方式写了相当于不加泛型,也就是支持一个
Object类型的集合,形参 void method(List<? extends Animal> list){}这里要求泛型是Animal类型或者是其子类。void method(List<? super Dog> list){}这里要求泛型是
Dog类型或者Dog的父类。Map接口,HashMap默认长度是一个16的数组,然后每一个数组中的元素都属于一个链表的头,默认 的负载因子是0.75,当数组的使用率达到百分之75
的时候扩容两倍。键和值都允许为NULL,但是键不能重复,所以key为NULL的情况只能有一个,多次添加的话将覆盖原来的值。线程是不安全的,无序,只能使用增强for循环或这迭代器遍历。HashSet不允许重复,无序,去重复的原理是根据我们的hashCode方法和equals方法来决定这个元素能不能被插入。最后学习了Collections工具类,本类提供一些用于操作集合的方法。max、min、compareTo、sort、binarySearch(二分查找法)。
第五天学习了TreeSet类,它是SortedSet接口的实现类,这个类可以保证集合的顺序,底层实现的TreeMap.TreeMap是SortedMap接口的实现类,这个类实现了一个可排序的Map集合。Properties类,也是属于一个Map的实现类,用来配置文件。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值