本周学习笔记

Date类

Date类,的对象在JAVA中代表的是当前所在系统的此刻日期时间。

Data类记录时间有两种形式

1:日期对象

2:时间毫秒值

指的是从1970年1月1日,00:00:00走到此刻,总的毫秒数

SimpleDateFormat类

可以对date对象或时间毫秒只格式化

也可以把字符串的时间形式解析成日期对象

public static Calendar getInstance():

获取当前日历对象

Calendar 对象= Calendar.getInstance();

拿到此刻日历对象。

Calendar常用方法

包装类

就是八种基本数据类型,对应的引用类型

自动装箱:基本类型的数据和变量可以直接赋值给包装类型的变量。

自动拆箱:包装类型的变量可以直接赋值给基本数据类型的变量。

包装类的特有功能

.包装类的变量的默认值可以是 null ,容错率更高。

.可以把基本类型的数据转换成字符串类型(用处不大)

调用 toString ()方法得到字符串结果。调用 Integer . toString (基本类型的数据)。

可以把字符串类型的数值转换成真实的数据类型(很有用)

Integer . parselnt ("字符串类型的整数")

Double . parseDouble ("字符串类型的小数")。

parse~~可以替换为value0f。 Integer.toString 可以直接定义String 名 = 基本类型数据 + ""。

正则表达式

正则表达式支持爬取信息。

Arrays类

数组操作工具类,专门用于操作数组元素的。

二分查找的数组对象需要提前排好顺序。不存在返回 -(应该存在的索引位置+1)。

数组的二分查找的实现步骤是什么样的?

定义变量记录左边和右边位置。

使用 while 循环控制查询(条件是左边位置<=右边位置)

循环内部获取中间元素索引

判断当前要找的元素如果大于中间元素,左边位置=中间索引+1

判断当前要找的元素如果小于中间元素,右边位置=中间索引﹣1

判断当前要找的元素如果等于中间元素,返回当前中间元素索引。

使用比较器对象,只支接引用数据类型的排序。

自定义排序规则

设置 Comparator 接口对应的比较器对象,来定制比较规则。

如果认为左边数据大于右边数据返回正整数

如果认为左边数据小于右边数据返回负整数

如果认为左边数据等于右边数据返回0

Lambda 表达式

. Lambda 表达式是 JDK 8开始后的一种新语法形式。.作用:简化匿名内部类的代码写法。

Lambda 表达式的简化格式(匿名内部类被重写方法的形参列表)->(被重写方法的方法体代码。

(注:->是语法形式,无实际含义 )

注意: Lambda 表达式只能简化函数式接口的匿名内部类的写法形式

函数式接口

首先必须是接口、其次接口中有且仅有一个抽象方法的形式

通常会在接口上加上一个@ Functionallnterface 注解,标记该接口必须是满足函数式接口。

Lambda 表达式的省略写法(进一步在 Lambda 表达式的基础上继续简化)

1参数类型可以省略不写。

2如果只有一个参数,参数类型可以省略,同时()也可以省略。

3如果 Lambda 表达式的方法体代码只有一行代码。可以省略大括号不写,同时要省略分号!

4如果 Lambda 表达式的方法体代码只有一行代码。可以省略大括号不写。此时,如果这行代码是 return 语句,必须省略 return 不写,同时也必须省略","不写

集合

(支持泛型 Q ,只能储存引用数据类型的数据;存储基本数据类型用包装类)(储存的元素都是对象地址)

Collection集合的遍历方式:

方式一:迭代器

可用while循环遍历。

方式二:增强for循环

方式三:Lamabda表达式。

数据结构

数据结构是计算机底层存储、组织数据的方式。是指数据相互之间是以什么方式排列在一起的。通常情况下,精心选择的数据结构可以带来更高的运行或者存储效率

常见数据结构:

数组:内存连续区域,查询快,增删慢。

链表:元素是游离的,查询慢,收尾操作快。

二叉树: 永远只有一个根节点,每个节点不超过两个子节点的树。

查找二叉树: 小的左边,大的右边,但是可能树很高,查询性能变差。

平衡查找二叉树: 让树的高度差不大于1,增删改查都提高了。

红黑数(就是基于红黑规则实现了自平衡的排序二叉树)

List系列集合

ArraysList集合底层原理:

当元素超过容量时进行1.5倍扩容。

LinkedList集合:

栈: 压栈: addFirst()可变为 push() 出栈: removeFirst 可变为 pop();

队列: 入队: addLast(); 出队: removeFirst();

集合的并发修改异常问题:

当从集合中找出某个元素并删除的时候可能会出现的一些问题。

(1)遍历存在问题:

迭代器遍历集合且直接用集合删除元素的时候可能出现。

增强for循环遍历集合且直接用集合删除元素的时候可能出现。

(2)遍历且删除元素不出现问题:

迭代器遍历集合但是用迭代器自己的删除方法操作可以解决。

使用for循环遍历并删除元素不会存在这个问题。(倒删或者删除后i--)

泛型深入

泛型:可以在编译阶段约束操作的数据类型,并进行检查。(统一数据类型)(集合体系的全部接口和实现类都支持泛型的使用)

泛型格式: <数据类型> 注意:泛型只支持引用数据类型。

通配符: ? (可以在“使用泛型”的时候代表一切类型

泛型的上下限:

?extends Car:?必须是Car或者其子类;泛型上限

?super Car:?必须是Car或者其父类,泛型下限

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值