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

相关文章

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是

Python主动抛出异常的各种用法和场景分析

《Python主动抛出异常的各种用法和场景分析》在Python中,我们不仅可以捕获和处理异常,还可以主动抛出异常,也就是以类的方式自定义错误的类型和提示信息,这在编程中非常有用,下面我将详细解释主动抛... 目录一、为什么要主动抛出异常?二、基本语法:raise关键字基本示例三、raise的多种用法1. 抛

Golang 日志处理和正则处理的操作方法

《Golang日志处理和正则处理的操作方法》:本文主要介绍Golang日志处理和正则处理的操作方法,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录1、logx日志处理1.1、logx简介1.2、日志初始化与配置1.3、常用方法1.4、配合defer

Java Lambda表达式的使用详解

《JavaLambda表达式的使用详解》:本文主要介绍JavaLambda表达式的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、前言二、Lambda表达式概述1. 什么是Lambda表达式?三、Lambda表达式的语法规则1. 无参数的Lambda表

Java空指针异常NullPointerException的原因与解决方案

《Java空指针异常NullPointerException的原因与解决方案》在Java开发中,NullPointerException(空指针异常)是最常见的运行时异常之一,通常发生在程序尝试访问或... 目录一、空指针异常产生的原因1. 变量未初始化2. 对象引用被显式置为null3. 方法返回null

redis在spring boot中异常退出的问题解决方案

《redis在springboot中异常退出的问题解决方案》:本文主要介绍redis在springboot中异常退出的问题解决方案,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴... 目录问题:解决 问题根源️ 解决方案1. 异步处理 + 提前ACK(关键步骤)2. 调整Redis消费者组

springboot项目redis缓存异常实战案例详解(提供解决方案)

《springboot项目redis缓存异常实战案例详解(提供解决方案)》redis基本上是高并发场景上会用到的一个高性能的key-value数据库,属于nosql类型,一般用作于缓存,一般是结合数据... 目录缓存异常实践案例缓存穿透问题缓存击穿问题(其中也解决了穿透问题)完整代码缓存异常实践案例Red

Java内存区域与内存溢出异常的详细探讨

《Java内存区域与内存溢出异常的详细探讨》:本文主要介绍Java内存区域与内存溢出异常的相关资料,分析异常原因并提供解决策略,如参数调整、代码优化等,帮助开发者排查内存问题,需要的朋友可以参考下... 目录一、引言二、Java 运行时数据区域(一)程序计数器(二)Java 虚拟机栈(三)本地方法栈(四)J

解决Java异常报错:java.nio.channels.UnresolvedAddressException问题

《解决Java异常报错:java.nio.channels.UnresolvedAddressException问题》:本文主要介绍解决Java异常报错:java.nio.channels.Unr... 目录异常含义可能出现的场景1. 错误的 IP 地址格式2. DNS 解析失败3. 未初始化的地址对象解决

python利用backoff实现异常自动重试详解

《python利用backoff实现异常自动重试详解》backoff是一个用于实现重试机制的Python库,通过指数退避或其他策略自动重试失败的操作,下面小编就来和大家详细讲讲如何利用backoff实... 目录1. backoff 库简介2. on_exception 装饰器的原理2.1 核心逻辑2.2