day05-面向对象-异常Lambda算法正则

2024-09-02 09:52

本文主要是介绍day05-面向对象-异常Lambda算法正则,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、⭐异常⭐

1.1 异常

1.2 异常处理

1.2.1 抛出异常(throws)

在Java的方法调用中,如果一个方法中出现了异常,本方法自己不处理,默认是会抛给调用方法去处理的此时要注意的是,如果发生的是非运行时异常,需要在方法上明确使用throws关键字声明抛出
​
格式public void 方法名 throws 异常1 ,异常2 ,异常3 ..{方法体throw new Exception()}
public class Demo2 {
​public static void main(String[] args) throws Exception {print();}public static void print() throws Exception {new SimpleDateFormat("yyyy-MM-dd").parse("2019");}
}

throws只抛出并不处理,使得代码能够继续编译(即继续写代码),但运行报错,上面代码运行结果如下:

1.2.2 捕获异常(try...catch)

直接在当前方法,发生异常的代码外使用try--catch--结构捕获并处理异常异常处理后,后续的代码是可以继续执行的
​
格式public void 方法名{try{// 方法体}catch(异常类型1 变量){// 处理异常}catch(异常类型2 变量){// 处理异常}}
public class Demo3 {public static void main(String[] args) {print();}public static void print(){//1.运行时异常String srt = null;//System.out.println("字符串长度:" + srt.length());
​try {//java代码,jdk会监控try中的代码,一旦出现指定类型的错误,会进入到catch中做容错处理System.out.println("字符串长度:" + srt.length());}catch (Exception e){System.out.println("字符串为空,长度为0");}
​}
}

 

1.2.3 自定义异常

自定义异常Java无法为这个世界上全部的问题都提供异常类来代表,如果以后我们自己写的代码中的某种问题,想通过异常来表示,以便用异常来管理该问题,那就需要自己来定义异常类了。
​
自定义运行时异常1、定义一个异常类,继承RuntimeException2、在类中提供构造函数3、在需要抛出异常的地方使用throw关键字 抛出异常类的对象自定义编译时异常1、定义一个异常类,继承Exception2、在类中提供构造函数3、在需要抛出异常的地方使用throw关键字 抛出异常类的对象
注意编译时异常,在编写代码的过程中必须手动处理
异常的作用1、异常是用来查找系统bug 的关键参考信息2、异常可以作为方法内部一种特殊的返回值,以便通知上层调用者,代码底层的执行情况

 

public class Demo4 {public static void main(String[] args) {//模拟用户登录,用户名:admin,密码123456System.out.println(login("admin","123456"));}
​//设置登录的方法public static String login(String username,String password) {
​if (!username.equals("admin")) {//1.用户名错误,用户登录失败throw new LoginException("用户名错误,用户登录失败");} else if (!password.equals("123456")) {//2.用户密码错误,用户登录失败throw new LoginException("用户密码错误,用户登录失败");} else {//3.用户登录成功,返回用户信息return "用户登录成功,用户名" + username;}
​}
​
}
​
//自定义运行时异常类
class LoginException extends RuntimeException{//有参构造public LoginException(String message) {super(message);}
}
public class Demo5 {public static void main(String[] args) throws LoginException2{//模拟用户登录,用户名:admin,密码123456System.out.println(login("admin","1023456"));}
​//设置登录的方法public static String login(String username,String password) throws LoginException2 {
​if (!username.equals("admin")) {//1.用户名错误,用户登录失败throw new LoginException2("用户名错误,用户登录失败");}else if (!password.equals("123456")) {//2.用户密码错误,用户登录失败throw new LoginException2("用户密码错误,用户登录失败");}else {//3.用户登录成功,返回用户信息return "用户登录成功,用户名" + username;}}
​
}
​
//自定义编译时异常类
class LoginException2 extends Exception {public LoginException2(String message) {super(message);}
}

二、⭐Lambda表达式⭐

Lambda表达式是JDK8开始新增的一种语法形式,主要用来简化匿名内部类代码的书写
​
Lambda格式(被重写方法的参数列表)->{被重写方法的方法体;}
​
Lambda使用前提Lambda只能操作函数式接口(有且仅有一个抽象方法的接口,被FunctionalInterface注解修饰)(接口才有Lambda,父子关系没有)
public class Demo1 {public static void main(String[] args) {//匿名内部类操作接口Person person = new Person() {@Overridepublic void eat() {System.out.println("吃饭");}};person.eat();//Lambda简化Person person1 = () -> {System.out.println("吃软饭");};person1.eat();System.out.println("===========================================");
​//匿名内部类操作抽象类Animal animal = new Animal() {@Overridevoid eat() {System.out.println("狗吃肉脯");}};//无法使用Lambda简化animal.eat();
​
​}
​
}
​
​
//接口
interface Person {void eat();
}
​
//抽象类
abstract class Animal {abstract void eat();
}

 

三、方法引用

JDK8新特性,方法引用主要用来简化、替换Lambda表达式
​
方法引用分类1、静态方法的引用2、实例方法的引用3、特定类型方法的引用4、构造器引用
​
小提示先写匿名内部类,发现能化再化(写的多了就热练了)
​
​
1、静态方法的引用:某个Lambda只是调用一个静态方法,并且前后参数一致,即可使用  类名::静态方法
​
2、实例方法的引用:某个Lambda只是调用一个实例方法,并且前后参数一致,即可使用  对象名::实例方法
3、特定类型方法的引用:如果某个Lambda只是调用一个实例方法,并且前面参数列表中第一个参数作为主调,后面的参数作为入参,即可使用  类型::方法
4、构造器引用如果某个Lambda表达式里只是在创建对象,并且前后参数情况一致,就可以使用构造器引用   类名::new 

四、⭐常见算法⭐

4.1 冒泡排序

冒泡排序相邻的两个元素进行比较,小的放左边大的放右边,完成升序排列
​
实现步骤确定总共需要做几轮: 数组长度-1每轮比较几次: 轮数从0计数的话, 就是数组长度-1-当前轮数比较规则: 相邻两个元素比较,大的放在右边

 

4.2 选择排序

选择排序每轮选择当前位置,开始找后面的最小值,与当前位置交换
​
关键点分析确定总共需要做几轮: 数组长度-1每次的基准位:轮数从0计数的话, 就是基准位索引敲好就是轮数比较规则: 以每次的第一个为基准做比较,谁小谁来基准位

 

public class Demo2 {public static void main(String[] args) {int[] arr = {5, 2, 3, 1};selectionSort(arr);System.out.println(Arrays.toString(arr));}
​
​private static void selectionSort(int[] arr) {// 控制轮数:确定总共需要做几轮: 数组长度-1for (int i = 0; i < arr.length-1; i++) {// 每次的基准位:轮数从0计数的话, 就是基准位索引恰好就是轮数(i+1)for (int j = i+1; j < arr.length; j++) {if(arr[i] > arr[j]){int temp = arr[i];arr[i] = arr[j];arr[j] = temp;}}}}
}
​

4.3 折半查找(二分查找)

二分查找/折半查找前提是数组有序特点是每一次查找完成,会舍去一半元素
​
思路分析1、定义两个指针,指向数组第一个和最后一个索引位置2、循环查找,min小于等max则继续(三个指针可能重叠的)3、每次循环进来,重新计算中间指针4、判断情况1:如果mid指向的元素就是num,则返回mid5、判断情况2:如果要查找的元素,在左半边,舍弃max重新计算6、判断情况3:如果要查找的元素,在右半边,舍弃min重新计算7、循环结束没有找到,则代表不存在,返回-1
public class Demo1 {public static void main(String[] args) {int[] arr = {10, 23, 39, 45, 59, 166, 728, 810, 999};
​System.out.println("索引位置为:" + binarySearch(arr, 166));//索引位置为:5System.out.println("索引位置为:" + binarySearch(arr, 200));//索引位置为:-1
​}
​//二分查找private static int binarySearch(int[] arr, int num) {//1.设置返回索引int index = -1;//2.设置开始和结束索引int min = 0;int max = arr.length - 1;//3.使用while循环,条件:左侧开始索引 <= 右侧结束索引while (min<=max){//4.计算中间索引int mid = (min + max)/2;//5.使用中间索引的数据和需要查询的num比较//5.1 数据一致,返回索引位置if(num == arr[mid]){index = mid;break;}else if(num < arr[mid]){//5.2 数据小于中间索引的数据,舍弃右侧数据,重新计算max = mid - 1;}else{//5.3 数据大于中间索引的数据,舍弃左侧数据,重新计算min = mid + 1;}}//如果min>max,则代表没有找到,返回-1//6.循环结束,返回索引位置return index;}
}

这篇关于day05-面向对象-异常Lambda算法正则的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1129633

相关文章

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

Java异常架构Exception(异常)详解

《Java异常架构Exception(异常)详解》:本文主要介绍Java异常架构Exception(异常),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. Exception 类的概述Exception的分类2. 受检异常(Checked Exception)

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时

Java报NoClassDefFoundError异常的原因及解决

《Java报NoClassDefFoundError异常的原因及解决》在Java开发过程中,java.lang.NoClassDefFoundError是一个令人头疼的运行时错误,本文将深入探讨这一问... 目录一、问题分析二、报错原因三、解决思路四、常见场景及原因五、深入解决思路六、预http://www

一文带你深入了解Python中的GeneratorExit异常处理

《一文带你深入了解Python中的GeneratorExit异常处理》GeneratorExit是Python内置的异常,当生成器或协程被强制关闭时,Python解释器会向其发送这个异常,下面我们来看... 目录GeneratorExit:协程世界的死亡通知书什么是GeneratorExit实际中的问题案例

Java捕获ThreadPoolExecutor内部线程异常的四种方法

《Java捕获ThreadPoolExecutor内部线程异常的四种方法》这篇文章主要为大家详细介绍了Java捕获ThreadPoolExecutor内部线程异常的四种方法,文中的示例代码讲解详细,感... 目录方案 1方案 2方案 3方案 4结论方案 1使用 execute + try-catch 记录

如何通过Golang的container/list实现LRU缓存算法

《如何通过Golang的container/list实现LRU缓存算法》文章介绍了Go语言中container/list包实现的双向链表,并探讨了如何使用链表实现LRU缓存,LRU缓存通过维护一个双向... 目录力扣:146. LRU 缓存主要结构 List 和 Element常用方法1. 初始化链表2.

解决java.lang.NullPointerException问题(空指针异常)

《解决java.lang.NullPointerException问题(空指针异常)》本文详细介绍了Java中的NullPointerException异常及其常见原因,包括对象引用为null、数组元... 目录Java.lang.NullPointerException(空指针异常)NullPointer

golang字符串匹配算法解读

《golang字符串匹配算法解读》文章介绍了字符串匹配算法的原理,特别是Knuth-Morris-Pratt(KMP)算法,该算法通过构建模式串的前缀表来减少匹配时的不必要的字符比较,从而提高效率,在... 目录简介KMP实现代码总结简介字符串匹配算法主要用于在一个较长的文本串中查找一个较短的字符串(称为

通俗易懂的Java常见限流算法具体实现

《通俗易懂的Java常见限流算法具体实现》:本文主要介绍Java常见限流算法具体实现的相关资料,包括漏桶算法、令牌桶算法、Nginx限流和Redis+Lua限流的实现原理和具体步骤,并比较了它们的... 目录一、漏桶算法1.漏桶算法的思想和原理2.具体实现二、令牌桶算法1.令牌桶算法流程:2.具体实现2.1