系统运维系列之异常抛出后代码执行问题(java应用)

琅晓琳      2022-05-19     476

关键词:

1 问题描述
throw new Excpetion()之后,程序并没有向下继续运行,抛出异常后直接跳出,后面的功能不再执行。

//抛出异常:Exception in thread "main" java.lang.NumberFormatException
//不会执行后面的输出语句
public static void main(String[] args) 
	String s = "a1b2c3";
	if(s.equals("a1b2c3")) 
	throw new NumberFormatException();
	 else 
	System.out.println(s);
	
	System.out.println(s);
	//function();

2 throw与throws的比较

(1) throws出现在方法函数头;throw出现在函数体;

(2) throws表示出现异常的一种可能性,并不一定会发生这些异常;throw则是抛出了异常,执行throw则一定抛出了某种异常对象;

(3) 可以使用throw关键字在指定的方法中抛出指定的异常;
	throw抛出指定的异常对象,我们就必须处理这个异常对象;
    throw关键字后边创建的是RuntineException或者是其子类,我们可以不处理,默认交给JVM处理(打印异常处理,中断程序);
    throw关键字后边创建的是编译异常(写代码时报错),我们就必须处理这个异常,要么throws,要么try...catch(4) throws关键字必须写在方法声明处;
	当方法内部抛出异常对象时,那么我们就必须处理这个异常对象;
	可以使用throws关键字处理异常处理对象,会把异常对象声明抛出给方法的调用者,最终交给JVM处理--->中断处理。

3 子父类异常

(1) 如果父类抛出多个异常,子类重写父类方法时,抛出和父类相同的异常或者是父类异常的子类或者不抛出异常;

(2) 父类方法没有抛出异常,子类重写父类方法时也不可抛出异常。此时子类产生该异常只能捕获处理,不能声明抛出。

4 运行时异常和非运行时异常

(1) unchecked exceptions(运行时异常)都是RuntimeException类及其子类异常,就是我们在开发中测试功能时程序终止,控制台出现的异常,比如:
NullPointerException(空指针异常)IndexOutOfBoundsException(下标越界异常)ClassCastException(类转换异常)ArrayStoreException(数据存储异常,操作数组时类型不一致);
IO操作的BufferOverflowException异常;
ArithmeticException(由于除数为0引起的异常)FileNotFoundException(未找到指定文件引起异常)(2) checked exceptions,非运行时异常(编译异常):
RuntimeException以外的异常,类型上都属于Exception类及其子类;
非运行时异常必须进行处理(捕获或向上抛出),如果不处理,程序将出现编译错误;
IOExceptionSQLException等以及用户自定义的Exception

参考资料:
https://blog.csdn.net/qq1424035130/article/details/83010718 运行时异常和非运行时异常(一般异常)的区别
https://blog.csdn.net/yiminghd2861/article/details/115700585?spm=1001.2101.3001.6650.4&utm_medium=distribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7ERate-4-115700585-blog-80334431.pc_relevant_antiscanv2&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2%7Edefault%7ECTRLIST%7ERate-4-115700585-blog-80334431.pc_relevant_antiscanv2&utm_relevant_index=9 Java问题:在Java程序中抛出异常后,其之后的代码还会继续执行吗

系统运维系列之堆栈理解(java应用)(代码片段)

1概述java虚拟机内存分为:堆(heap)、栈(stack)、方法区(methodarea)等,整体来说:堆:new出来的数组或者对象;栈:存储局部变量;方法区:代码区;寄存器࿱ 查看详情

系统运维系列之socket和serversocket的简单介绍(java应用)

Socket类代表一个客户端套接字,即任何时候连接到一个远程服务器应用时构建所需的socket。现在,要实现一个服务器应用,需要不同的做法。服务器需随时待命,因为不知道客户端什么时候会发来请求,此时&#... 查看详情

系统运维系列之mysql联合索引的使用分析(代码片段)

1前言日常优化中可能会遇到相同的数据在本地执行很快但是在服务器上执行很慢的问题,或者无论是在本地还是在服务器上都执行的很慢,可以分为两个方面排查2第一部分本地执行速度>服务器执行速度一般这种情况... 查看详情

系统运维系列之java中实现多线程的方式补充

1介绍接本专题博客之系统运维系列之java中实现多线程的方式上篇博客提到多线程使用的4种方式,分别是:实现方式1:继承Thread类,重写该类的run方法;实现方式2:实现Runnable接口,并重写该接口的run... 查看详情

系统运维系列之mysql部分学习整理3

1存储过程语法结构:举例:无参CREATEPROCEDUREsql()SELECTVERSION();调用:CALLsql();有参IN:DELIMITER//(更改执行符号的命令)参数与语句中的字段不要重复,不要重复!如果p_id改成id,则会全部删除࿰... 查看详情

系统运维系列之mysql部分学习整理5(代码片段)

1应用场景在mysql数据库中查找数据,要求是数据为日期不连续数据,输入一个日期查询日期所在周指定周几的数据和上几周对应时间段数据(一个月内)。关于此问题网上资料未曾有明确的解决方案,本篇博... 查看详情

系统运维系列之mysql部分学习整理2

1字符函数使用举例:CONCAT_WS相比于CONCAT可以简化语句SELECTCONCAT(id,’-’,age)ASpathFROMuser;SELECTCONCAT_WS(’-’,id,age)ASpathFROMuser;SELECTFORMAT(id,3)ASnumFROMuser;SELECTLEFT(‘abcdef’,2);—>ab举例:SELECT 查看详情

系统运维系列之java.lang.nullpointerexception出现原因研究和解决方案分析(代码片段)

1原因分析:空指针异常都是因为调用null对象的方法,就是一个对象还没有没有正常初始化就先调用它的方法;程序在使用或访问一个对象的引用时,而该对象等于null则被抛出。2场景分析:2.1接口类型的对象... 查看详情

系统运维系列之clickhouse数据类型整理

Clickhouse支持的数据类型在system.data_type_families表中检查数据类型名称以及是否区分大小写,这个表中存储了ClickHouse支持的所有数据类型。select*fromsystem.data_type_familieslimit10;Int说明ClickHouse中整形分为Int8、Int16、Int32、Int64来表示... 查看详情

系统运维系列之linux系统下常用查找命令整理(代码片段)

1前言网上关于linux命令大多写的很细很全,但是真正使用起来需要根据自己的场景进行拼接,本博客建立在实际场景下,在实际问题中使用linux查找命令。2grep命令使用场景:查找日志中的关键词,并且限定时... 查看详情

自动化运维系列之ansible命令应用基础(模块的应用)持续更新中···(代码片段)

自动化运维系列之Ansible命令应用基础(模块的应用)模块简介Ansible可以使用命令行方式进行自动化管理,基本语法如下:ansible<host-pattern>[-mmodule_name][-aargs]<host-pattern>对哪些主机生效[-mmodule_name]需要使用的模块[-aargs]模块... 查看详情

系统运维系列之记载一次windows系统下tomcat启动报错的问题(代码片段)

1问题简介最近遇到一个问题,在windows系统下部署tomcat项目,cmd命令启动时频繁报错,比如Unsupportedmajor.minorversion52.0,且cmd界面上打印出来的日志为乱码;最后在关闭tomcat时发现关不掉,出现项目挂起但是... 查看详情

系统运维系列之mysql部分学习整理4

1存储引擎查看数据库表创建命令:SHOWCREATETABLEtab1;支持的存储引擎:MylSAM:快速存储;InnoDB:带有事务回滚机制;MemorycsvArchive修改存储引擎的方式:通过修改MySQL配置文件实现default-storage-engine=engine... 查看详情

系统运维系列之mysql部分学习整理1

1前言本部分对于MySQL数据库工作机制及其语法做一个整理,用于之后重点内容的查询和交流。2包含内容数据库工作机制、语法基础、重要内容整理、语句优化、效率提升等。3MySQL的字段约束3.1其中AUTO_INCREMENT必须和PRIMARYKEY一... 查看详情

系统运维系列之greenplumvacuum清理删除数据命令(代码片段)

...m完成清理工作后,那些空间并没有真正被释放给操作系统,只能被vacuum清理过的表和索引所利用 查看详情

系统运维系列之kafka手动设置offset(经典方法总结)(代码片段)

1问题背景在使用Kafka消费数据过程中,消费程序可能出现运行问题,导致消费不及时,消息堆积很多;尤其是消息消费后需要进行一列后处理,这种情况下就需要考虑一些方法来进行消费参数的设置。2举例测... 查看详情

系统运维系列之kafka配置分析及参数含义

补充:kafkamanager中lag的正数、0、负数的含义:正数:就是kafka数据积压了,消费速度小于生产速度;0:生产者和消费者速率基本相当,说明2者都工作正常;负数:说明kafka的消费者干活很快,分... 查看详情

系统运维系列之greenplum常用的toolkit和catalog监控语句

1表膨胀相关查询--该视图显示了那些膨胀的(在磁盘上实际的页数超过了根据表统计信息得到预期的页数)正规的堆存储的表。select*fromgp_toolkit.gp_bloat_diag;--所有对象的膨胀明细select*fromgp_toolkit.gp_bloat_expected_pages;2表倾斜... 查看详情