技术标签: java
程序运行时,发生的不被期望的事件,它阻止了程序按照程序员的预期正常执行,这就是异常。异常发生时,是任程序自生自灭,立刻退出终止,还是输出错误给用户?或者用C语言风格:用函数返回值作为执行状态?。
Java提供了更加优秀的解决办法:异常处理机制。
异常处理机制能让程序在异常发生时,按照代码的预先设定的异常处理逻辑,针对性地处理异常,让程序尽最大可能恢复正常并继续执行,且保持代码的清晰。
Java中的异常可以是函数中的语句执行时引发的,也可以是程序员通过throw 语句手动抛出的,只要在Java程序中产生了异常,就会用一个对应类型的异常对象来封装异常,JRE就会试图寻找异常处理程序来处理异常。
Throwable类是Java异常类型的顶层父类,一个对象只有是 Throwable 类的(直接或者间接)实例,他才是一个异常对象,才能被异常处理机制识别。JDK中内建了一些常用的异常类,我们也可以自定义异常。
Java标准库内建了一些通用的异常,这些类以Throwable为顶层父类。
Throwable又派生出Error类和Exception类。
错误:Error类以及他的子类的实例,代表了JVM本身的错误。错误不能被程序员通过代码处理,Error很少出现。因此,程序员应该关注Exception为父类的分支下的各种异常类。
异常:Exception以及他的子类,代表程序运行时发送的各种不期望发生的事件。可以被Java异常处理机制使用,是异常处理的核心。
其中分为两种异常1、检查异常 2 、 非检查异常
非检查异常(unckecked exception):Error 和 RuntimeException 以及他们的子类。javac在编译时,不会提示和发现这样的异常,不要求在程序处理这些异常。所以如果愿意,我们可以编写代码处理(使用try…catch…finally)这样的异常,也可以不处理。对于这些异常,我们应该修正代码,而不是去通过异常处理器处理 。这样的异常发生的原因多半是代码写的有问题。如除0错误ArithmeticException,错误的强制类型转换错误ClassCastException,数组索引越界ArrayIndexOutOfBoundsException,使用了空对象NullPointerException等等。
检查异常(checked exception):除了Error 和 RuntimeException的其它异常。javac强制要求程序员为这样的异常做预备处理工作(使用try…catch…finally或者throws)。在方法中要么用try-catch语句捕获它并处理,要么用throws子句声明抛出它,否则编译不会通过。这样的异常一般是由程序的运行环境导致的。因为程序可能被运行在各种未知的环境下,而程序员无法干预用户如何使用他编写的程序,于是程序员就应该为这样的异常时刻准备着。如SQLException , IOException,ClassNotFoundException 等。
简单的来说:非检查异常一般由代码错误产生,可以不用代码(使用try…catch…finally)处理也能通过编译,而非检查异常强制程序员做出代码处理,如果不处理则不能通过编译。
有2种不同的处理方式:使用try…catch…finally语句块处理它。或者,在函数签名中使用throws 声明交给函数调用者caller去解决。
try{
//try块中放可能发生异常的代码。
//如果执行完try且不发生异常,则接着去执行finally块和finally后面的代码(如果有的话)。
//如果发生异常,则尝试去匹配catch块。
}catch(SQLException SQLexception){
//每一个catch块用于捕获并处理一个特定的异常,或者这异常类型的子类。Java7中可以将多个异常声明在一个catch中。
//catch后面的括号定义了异常类型和异常参数。如果异常与之匹配且是最先匹配到的,则虚拟机将使用这个catch块来处理异常。
//在catch块中可以使用这个块的异常参数来获取异常的相关信息。异常参数是这个catch块中的局部变量,其它块不能访问。
//如果当前try块中发生的异常在后续的所有catch中都没捕获到,则先去执行finally,然后到这个函数的外部caller中去匹配异常处理器。
//如果try中没有发生异常,则所有的catch块将被忽略。
}catch(Exception exception){
//...
}finally{
//finally块通常是可选的。
//无论异常是否发生,异常是否匹配被处理,finally都会执行。
//一个try至少要有一个catch块,否则, 至少要有1个finally块。但是finally不是用来处理异常的,finally不会捕获异常。
//finally主要做一些清理工作,如流的关闭,数据库连接的关闭等。
}
需要注意的地方
1、try块中的局部变量和catch块中的局部变量(包括异常变量),以及finally中的局部变量,他们之间不可共享使用。
2、每一个catch块用于处理一个异常。异常匹配是按照catch块的顺序从上往下寻找的,只有第一个匹配的catch会得到执行。匹配时,不仅运行精确匹配,也支持父类匹配,因此,如果同一个try块下的多个catch异常类型有父子关系,应该将子类异常放在前面,父类异常放在后面,这样保证每个catch块都有存在的意义。
3、java中,异常处理的任务就是将执行控制流从异常发生的地方转移到能够处理这种异常的地方去。也就是说:当一个函数的某条语句发生异常时,这条语句的后面的语句不会再执行,它失去了焦点。执行流跳转到最近的匹配的异常处理catch代码块去执行,异常被处理完后,执行流会接着在“处理了这个异常的catch代码块”后面接着执行。
有的编程语言当异常被处理后,控制流会恢复到异常抛出点接着执行,这种策略叫做:resumption model of exception handling(恢复式异常处理模式 )
而Java则是让执行流恢复到处理了异常的catch块后接着执行,这种策略叫做:termination model of exception handling(终结式异常处理模式)
throws声明:如果一个方法内部的代码会抛出检查异常(checked exception),而方法自己又没有完全处理掉,则javac保证你必须在方法的签名上使用throws关键字声明这些可能抛出的异常,否则编译不通过。
throws是另一种处理异常的方式,它不同于try…catch…finally,throws仅仅是将函数中可能出现的异常向调用者声明,而自己则不具体处理。
采取这种异常处理的原因可能是:方法本身不知道如何处理这样的异常,或者说让调用者处理更好,调用者需要为可能发生的异常负责。
结论:在 try块中即便有return,break,continue等改变执行流的语句,finally也会执行。而如果try或catch和finally中同时存在return语句则执行finally的return语句。
public static void main(String[] args)
{
int result;
result = foo();
System.out.println(result); /2
result = bar();
System.out.println(result); /2
}
@SuppressWarnings("finally")
public static int foo()
{
trz{
int a = 5 / 0;
} catch (Exception e){
return 1;
} finally{
return 2;
}
}
@SuppressWarnings("finally")
public static int bar()
{
try {
return 1;
}finally {
return 2;
}
}
数据可视化要使用plot函数来绘制图形,需要执行以下步骤:通过指定要绘制函数的变量x的值的范围来定义x。定义函数,y = f(x)调用plot命令,如下:plot(x,y)以下示例将演示该概念。下面绘制x的值范围是从0到100,使用简单函数y = x,增量值为5。创建脚本文件并键入以下代码 -x = [0:5:100];y = x;plot(x, y)在图上添加标题,标签,...
ZigBee远程无线点灯一、任务要求:二、任务逻辑分析:三、逻辑代码实现:四、开发中注意的事项:一、任务要求:大棚种植区改造过程中提出新的需求,要求部分设备需要支持短距离无线通讯控制风扇功能,该功能需要选手通过编程自行设计并实现。任务要求: 使用两块黑色 ZigBee 开发板,分别命名为 A、B 并用标签纸贴上。 为板 B 上装一个继电器并连接一个风扇。 点击板 A 的 SW1 按键可以控制板 B 连接的灯的启动或关闭。二、任务逻辑分析:三、逻辑代码实现:ZigBee A板的主要
HashMap是Hashtable的轻量级实现(非线程安全的实现),他们都完成了Map接口,主要区别在于HashMap允许空(null)键值(key),由于非线程安全,效率上可能高于Hashtable。HashMap允许将null作为一个entry的key或者value,而Hashtable不允许。HashMap把Hashtable的contains方法去掉了,改成containsvalue和co...
最好的防cc办法——别到处乱发自己的网站域名,不要到处求打,不要对自己的服务器有过大的信心。宝塔防火墙设置:插件页面→全局配置→cc防御→初始规则建议规则:个人博客——周期:1秒 频率:5次~15次 封锁时间:3600秒 增强模式:关闭 四层防御:开启 自动模式:开启论坛——周期:1秒 频率:3次 封锁时间:360秒 增强模式:关闭 四层防御:开启 自动模式:开启使用后,点击灰色的“全局应用”,否则对已添加站点无效,若服务器要站点个性化,仅修改站点即可。规则说明:每个用户每秒可以访问站点*次,
主要参考两篇文章总结下这几天所学,小白入门O(∩_∩)O哈哈~ 不喜勿喷zhttps://blog.csdn.net/qq_40309183/article/details/80630910https://blog.csdn.net/stormdony/article/details/79828842目的: 为了实现提取中国诗词网的诗词的标的和内容工具:beautifuls...
云服务器哪家好?国内云服务器十大品牌排行榜本榜单是按市场占有率、用户好评度、产品性价比等多维度进行排行的,国内云服务器十大品牌排行榜如下:第一名:阿里云(云服务器102元/年,直达官方活动现场:9i0i.cn/aliyun)阿里云——阿里巴巴集团旗下公司,是全球领先的云计算及人工智能科技公司。提供云服务器、云数据库、云安全、云企业应用等云计算服务,以及大数据、人工智能服务、精准定制基于场景的行业解决方案。专业快速备案,7x24小时售后支持,助企业无忧上云。第二名:腾讯云(云...
1、请你自我介绍一下你自己,回答提示:一般人回答这个问题过于平常,只说姓名、年龄、爱好、工作经验,这些在简历上都有,其实,企业最希望知道的是求职者能否胜任工作,包括:最强的技能、最深入研究的知识领域、个性中最积极的部分、做过的最成功的事,主要的成就等回答样本:”我叫XX,今年X岁,我看到在招聘启事上,这份工作需要xxx,这和我之前的工作经历中xxx非常类似。我有3年的开发工作经验,我对技术...
如何echarts设置title和图形的距离 ?效果图之前之后代码如下:题外话:之前想拉开title的图形的距离的目的是,为了实现自适应的时候,图注不会与title重叠,所以把title和图形的距离拉开,然后图注塞到中间,然后即使自适应屏幕再小,也不会发生图注和title挤兑在一块。但是百度的时候,基本上都是教你设置grid:{x:数字,y:数字,x2::数字,y2:数字},然后再告诉你分别代表拉开哪里的距离。最后实现不了,然后用上面的top之类的属性就实现了。...
问题背景:两个服务A和B,A使用Feign调用服务B的接口报错,显示B服务不可用,具体如下:产生以上错误的原因是B服务没有被发现,解决上面的问题可以从3个方面入手排查:排查一:首先到注册中心列表查看服务是否存在,是否成功注册:以上,服务已成功注册,若不存在需要在B服务的pom文件中添加以下依赖:<dependency> <groupId...
高效配置Linux代理服务器――Squid 2001-05-21 12:43 发布者:Crystal 阅读次数:335 毛毛 作为一种免费的网络操作系统,Linux越来越受到广大网络爱好者的欢迎,目前Internet上运行的主机有相当一部分采用的就是Linux,而且中国已经把Linux作为政府上网的指定网络操作系统。种种迹象表明,Linux正在逐渐走向成熟。为了解决Internet发展迅速和IP
web浏览器和web服务器的交互过程用户打开Chrom在地址栏输入 http://news.baidu.com/internet 会发生什么HTTP请求过程1.浏览器向DNS获取web服务器(www.baidu.com) 的IP地址;2.浏览器与IP地址为 115.239.211.112 的服务器进行TCP链接 端口为80;3.浏览器执行HTTP协议,发送GET /internet ...
一、APP的安装与升级1)升级中用户数据、设置、状态是否正常保留2)是否支持低版本、高版本的覆盖安装。覆盖安装后用户数据正常保存3)测试升级安装,升级安装后用户数据正常4)需考虑灰度升级的问题,提示是否友好,可以X掉5)强升是否正常,不升级app无法使用二、APP的启动与停止1)首次启动app正常进入loading页,loading页展示的时间、页面都正常2)启动时...