【进阶篇-Day8:JAVA中递归、异常的介绍】

目录

  • 1、递归的介绍和使用
    • 1.1 递归的介绍
    • 1.2 案例
      • `案例一:`
      • `案例二:`
      • `案例三:`
      • `案例四:`
    • 1.3 总结
  • 2、`异常的介绍和使用`
    • 2.1 异常的介绍:
      • (1)能够看懂异常
      • (2)异常的体系接口和分类
      • (3)总结
    • 2.2 异常的处理方式
      • `(1)异常的默认处理流程`
      • `(2)异常处理方式 try...catch和throw抛出`
      • `(3)总结`
    • 2.3 自定义异常
    • 2.4 练习

1、递归的介绍和使用

1.1 递归的介绍

在这里插入图片描述

package com.itheima.recursion;/*** Title: RecurisonDemo1* Describe: 类的功能* Name: masizhou* Date: 2024/7/11* Copyright: @2022 by masizhou*/public class RecurisonDemo1 {/*** 递归介绍:方法直接或间接地调用本身*/public static void main(String[] args) {methodA();}public static void methodA(){methodB();}public static void methodB(){methodC();}public static void methodC(){methodA();}
}

上述方法会发生栈内存溢出异常,如下:
在这里插入图片描述

1.2 案例

案例一:

在这里插入图片描述

package com.itheima.recursion;public class RecurisonDemo2 {public static void main(String[] args) {/*** 需求:使用递归求5的阶乘*/int result = jc(5);System.out.println("5的阶乘是:" + result);//5的阶乘是:120}public static int jc(int num){if (num == 1){return 1;}return jc(num - 1) * num;}
}

栈内存图分分析:
在这里插入图片描述

案例二:

在这里插入图片描述

package com.itheima.recursion;public class RecurisonDemo3 {public static void main(String[] args) {/*** 需求:使用递归求1~n之和*/int result = sum(100);System.out.println(result);//5050}public static int sum(int num){if (num == 1){return 1;}return num + sum(num - 1);}
}

案例三:

在这里插入图片描述

package com.itheima.recursion;public class RecurisonDemo4 {public static void main(String[] args) {/*** 需求:使用递归实现斐波那契数列:1 1 2 3 5 8 13 21...*/int result = f(20);System.out.println(result);//6765}public static int f(int num){if (num <= 2){return 1;}return f(num - 1) + f(num - 2);}
}

案例四:

在这里插入图片描述

package com.itheima.recursion;public class RecursionDemo5 {public static void main(String[] args) {/*** 需求:猴子吃桃 (n / 2) - 1*/int result = eat(1);System.out.println(result);//1534}public static int eat(int day){if (day == 10){return 1;}// 今天的桃子数 = (明天桃子数+1) * 2return 2 * (eat(day + 1) + 1);}
}

1.3 总结

在这里插入图片描述

2、异常的介绍和使用

2.1 异常的介绍:

在这里插入图片描述
在这里插入图片描述

(1)能够看懂异常

package com.itheima.expection;public class ExceptionDemo1 {/*** 阅读异常信息:从下往上*          1、找异常错误位置*          2、异常名称*          3、异常原因*/public static void main(String[] args) {mothed();}public static void mothed(){int[] arr = {1, 2, 3};System.out.println(arr[10]);}
}

上述代码会抛出异常,异常信息如下:
在这里插入图片描述

在阅读异常时,遵循从下往上的原则:
- 1、找异常错误位置
- 2、异常名称
- 3、异常原因

注:要是遇到不认识的异常怎么办呢?
答:所有的异常都是,因此把这个类复制下来,到Java的API文档去看详细信息即可。

(2)异常的体系接口和分类

在这里插入图片描述

package com.itheima.expection;import java.io.IOException;
import java.text.ParseException;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.logging.FileHandler;public class ExceptionDemo2 {public static void main(String[] args) throws ParseException, IOException {/*** - 编译时异常:编译阶段就出现的异常(语法错误不算)。需要在运行之前给出解决方案。* - 运行时异常:编译过了,运行期间【可能会出现的异常】*/SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy年MM月dd");Date parse = simpleDateFormat.parse("2008年12月12日");//编译异常,需要给出解决方案FileHandler f = new FileHandler("D:\\a.txt");//编译异常,需要给出解决方案}
}

在这里插入图片描述
在这里插入图片描述

(3)总结

在这里插入图片描述

2.2 异常的处理方式

(1)异常的默认处理流程

在这里插入图片描述

(2)异常处理方式 try...catch和throw抛出

在这里插入图片描述

在这里插入图片描述

package com.itheima.expection.handle;
public class HandleDemo1 {/*** 异常的处理方式:* 1、try...catch捕获异常*      好处:   异常对象可以被捕获,后续的代码可以继续执行*      格式:*              try{*                  可能会出现异常的代码*              } catch(异常名称 对象名){*                  异常的处理方案*              }*      执行流程:*              1、执行try{}中的代码,看是否有异常对象*              2、没有:catch就不会捕获,后续代码继续执行*              3、有:catch捕获异常对象,执行catch{}中的处理方案,后续代码继续执行* 2、throw 抛出异常*** ----------------------------------------------------------------------------** 问题:正在面临的异常,是否需要暴露出来*      - 不需要暴露:try...catch捕获*      - 需要暴露:抛出异常*/public static void main(String[] args) {//1、try...catch捕获异常System.out.println("开始");try {System.out.println(10/0);  // new ArithmeticException();}catch (ArithmeticException e){System.out.println("捕获了运算异常");}System.out.println("结束");}
}

(3)总结

在这里插入图片描述
在这里插入图片描述

2.3 自定义异常

在这里插入图片描述

在这里插入图片描述

package com.itheima.expection.handle;/*** 自定义运行异常*/public class MyException extends RuntimeException{public MyException() {}public MyException(String message) {super(message);}
}
package com.itheima.expection.handle;import java.util.Scanner;public class HandleDemo2 {/*** 使用自定义异常**/public static void main(String[] args) {try {myFunction();//此方法会抛出自定义的异常} catch (MyException e) {System.out.println(e.getMessage());}}public static void myFunction(){throw new MyException("我的自定义异常");}
}

在这里插入图片描述

2.4 练习

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/44392.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Go语言map并发安全,互斥锁和读写锁谁更优?

并发编程是 Go 语言的一大特色&#xff0c;合理地使用锁对于保证数据一致性和提高程序性能至关重要。 在处理并发控制时&#xff0c;sync.Mutex&#xff08;互斥锁&#xff09;和 sync.RWMutex&#xff08;读写锁&#xff09;是两个常用的工具。理解它们各自的优劣及擅长的场景…

苹果入局,AI手机或将实现“真智能”?

【潮汐商业评论/原创】 “AI应用智能手机不就是现在的AI手机。” 当被问到现阶段对AI手机的看法时&#xff0c;John如是说。“术业有专攻&#xff0c;那么多APP在做AI功能&#xff0c;下载用就是了&#xff0c;也用不着现在换个AI手机啊。” 对于AI手机&#xff0c;或许大多…

上海市计算机学会竞赛平台2023年1月月赛丙组积木染色(二)

题目描述 &#x1d45b;n 块积木排成一排&#xff0c;需要给每块积木染色&#xff0c;颜色有 &#x1d45a;m 种。请问有多少种方法&#xff0c;从第二块积木开始统计&#xff0c;恰有 &#x1d45d;p 块积木与前一块积木颜色不同&#xff1f; 输入格式 三个整数分别表示 &a…

Windows安装和使用Doccano标注工具

简介 开源链接&#xff1a;GitHub - doccano/doccano: Open source annotation tool for machine learning practitioners. Open source annotation tool for machine learning practitioners. Doccano是一款开源的文本标注工具&#xff0c;由人工智能公司Hironsan开发并在G…

【算法】代码随想录之数组

文章目录 前言 一、二分查找法&#xff08;LeetCode--704&#xff09; 二、移除元素&#xff08;LeetCode--27&#xff09; 三、有序数组的平方&#xff08;LeetCode--977&#xff09; 四、长度最小的子数组&#xff08;LeetCode--209&#xff09; 五、螺旋矩阵II&#x…

花几千上万学习Java,真没必要!(二)

1、注释&#xff1a; java代码注释分3种&#xff1a; 单行注释&#xff1a;//注释信息 多行注释: /*注释信息*/ 文档注释:/**注释信息*/ public class TestComments {// 这是单行注释&#xff0c;用于注释单行代码或解释代码功能/* 这是多行注释&#xff0c;用于注释多行代码…

Kotlin runCatching try-catch耗时比较

Kotlin runCatching try-catch耗时比较 fun main(args: Array<String>) {val lists arrayListOf("z")val idx 10/***纳秒统计** ns&#xff08;nanosecond&#xff09;&#xff1a;纳秒。一秒的10亿分之一&#xff0c;10的-9次方秒。*   1纳秒0.000001 毫秒…

基于实现Runnable接口的java多线程

Java多线程通常可以通过继承Thread类或者实现Runnable接口实现。本文主要介绍实现Runnable接口的java多线程的方法, 并通过ThreadPoolTaskExecutor调用执行&#xff0c;以及应用场景。 一、应用场景 异步、并行、子任务、磁盘读写、数据库查询、网络请求等耗时操作等。 以下…

笔记:在Entity Framework Core中如何处理多线程操作DbContext

一、目的&#xff1a; 在使用Entity Framework Core (EF Core) 进行多线程操作时&#xff0c;需要特别注意&#xff0c;因为DbContext类并不是线程安全的。这意味着&#xff0c;你不能从多个线程同时使用同一个DbContext实例进行操作。尝试这样做可能会导致数据损坏、异常或不可…

C语言排序之快速排序

快速排序是一种高效的排序算法。它采用了分治的策略&#xff0c;通过选择一个基准元素&#xff0c;将待排序的序列划分为两部分&#xff0c;一部分的元素都比基准元素小&#xff0c;另一部分的元素都比基准元素大&#xff0c;然后对这两部分分别进行快速排序&#xff0c;从而实…

前端开发工具

Lodash 有普通的 CommonJS 版本&#xff08;通常称为 lodash&#xff09;和 ES6 模块版本&#xff08;称为 lodash-es&#xff09;。它们的主要区别包括&#xff1a; 模块化&#xff1a;lodash 是传统的 CommonJS 模块&#xff0c;可使用 require 或 import 引入&#xff1b;lo…

2024年,搞AI就别卷模型了

你好&#xff0c;我是三桥君 2022年11月30日&#xff0c;OpenAI发布了一款全新的对话式通用人工智能工具——ChatGPT。 该工具发布后&#xff0c;仅用5天时间就吸引了100万活跃用户&#xff0c;而在短短2个月内&#xff0c;其活跃用户数更是飙升至1亿&#xff0c;成为历史上增…

ARP协议介绍与ARP协议的攻击手法

ARP是什么&#xff1f; ARP是通过网络地址&#xff08;IP&#xff09;来定位机器MAC地址的协议&#xff0c;它通过解析网络层地址&#xff08;IP&#xff09;来找寻数据链路层地址&#xff08;MAC&#xff09;的网络传输协议。 对个定义不能理解的话&#xff0c;可以结合 TCP/I…

《恋与深空》2.0上线肉鸽模式,乙游玩家会买账吗?

乙游和肉鸽&#xff0c;看似八竿子打不着的两个赛道&#xff0c;被叠纸给融合起来了。 根据《恋与深空》官方消息&#xff0c;即将在7月15日更新的2.0交错视界版本中&#xff0c;会上线全新常驻玩法“混沌深网”&#xff0c;配置高随机性Roguelike模式&#xff0c;并搭载了管理…

理想文档发布了~一个集合了多个优秀开源项目的在线云文档

两年前我做了一个简单的在线云文档项目&#xff0c;选择了开源的思维导图、白板、流程图、幻灯片等项目&#xff0c;在它们基础上添加了云存储的功能&#xff0c;然后写了一个简单的工作台管理文件夹和文件&#xff1a; 放在了自己的个人网站上使用&#xff0c;同时写了一篇水文…

【Leetcode 每日一题】349. 两个数组的交集

给定两个数组 nums1 和 nums2 &#xff0c;返回 它们的 交集 。输出结果中的每个元素一定是 唯一 的。我们可以 不考虑输出结果的顺序 。 示例 1&#xff1a; 输入&#xff1a;nums1 [1,2,2,1], nums2 [2,2] 输出&#xff1a;[2]示例 2&#xff1a; 输入&#xff1a;nums…

[web]-代码审计-运维失误

打开页面可以看到如下&#xff1a; 1、查看源代码&#xff0c;发现验证码功能是正常生成的随机的&#xff0c;输入也没有过滤&#xff0c;无法采用爆破。 2、根据题目提示运维失误&#xff0c;使用dirsearch扫描&#xff0c;发现提交的地址check.php, 使用php5、.bak可以打开&…

2.The DispatcherServlet

The DispatcherServlet Spring的Web MVC框架与许多其他Web MVC框架一样&#xff0c;是请求驱动的&#xff0c;围绕一个中央Servlet&#xff08;即DispatcherServlet&#xff09;设计&#xff0c;该Servlet将请求分派给控制器&#xff0c;并提供其他功能以促进Web应用程序的开发…

创建I/O文件fopen

#include〈stdio.h〉 int mian(int argc,char *argv[]){ FILE *fp;//结构体fp fpfopen&#xff08;“1.txt”&#xff0c;“r”&#xff09;; }

程序的控制结构——if-else语句(双分支结构)【互三互三】

目录 &#x1f341; 引言 &#x1f341;if-else语句&#xff08;双分支结构&#xff09; &#x1f449;格式1&#xff1a; &#x1f449;功能&#xff1a; &#x1f449;程序设计风格提示&#xff1a; &#x1f449;例题 &#x1f449;格式2&#xff1a; &#x1f449;…