重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
Java异常概念
创新互联建站是一家集网站建设,菏泽企业网站建设,菏泽品牌网站建设,网站定制,菏泽网站建设报价,网络营销,网络优化,菏泽网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。
1)Java异常是Java提供的用于处理程序错误的一种机制.
2)所谓错误时指在程序运行中发生的一些异常事件(如:除0溢出,数组下标越界,所要读取的文件不存在)
3)设计良好的程序应该在异常发生时提供处理这些错误的方法,使得程序不会因为异常的发生而阻断或产生不可预见的结果
4)Java程序的执行过程中如果出现异常事件,可以生成一个异常类对象,该异常对象封装了异常事件信息并将被提交给Java运行时系统,这个过程被称为抛出(throw)异常
5)当Java运行时系统接收到异常对象时,会寻找能处理这一异常的代码并把当前异常对象交给其处理,这一过程称为捕获(catch)异常
Java异常的分类
J2SDK 中定义了很多异常类,这些类对映了各种各样可能出现的异常事件
1)Error:称为错误,由Java虚拟机生成并抛出,包括动态连接失败、虚拟机错误等,程序对其不作处理。
2)Exception:所有异常的父类,其子类对应了各种各样可能出现的异常事件,一般需要用户显示的声明或捕获
3)Runtime Exception:一类特殊的异常,如被0除、数组下标超出范围等,其产生比较频繁,处理麻烦,如果现实的声明或捕获将会对程序可读性和运行效率影响很大。因此有系统自动检测并将它们交给缺省的异常处理程序(用户不必对其处理)
异常的捕获和处理
1)try代码段包含可能产生异常的代码
2)try代码段后跟有一个或多个catch代码段
3)每个catch代码段声明其能处理的异常特定类型的异常并提供处理的方法
4)当异常发生时,程序会终止当前的流程,根据获取异常的类去执行相应的catch代码
5)finally段的代码无论是否发生异常都会执行
使用自定义的异常
1) 通过几成java.lang.Exception类声明自己的异常
2) 在方法适当的位置自动生成自定义异常的实力,并用throw语句抛出
3) 在方法的声明部分用throws语句声明该方法可能抛出的异常
重写方法需要抛出与原方法所抛出异常类型一致异常或不抛出异常
不要使用inputStream.available(),如果我没有记错的话,available返回的是没有被阻断的字节数(已经被缓冲的内容),可以尝试read(byte b[])方法,然后通过返回值是否-1来判断,如下。
int bytesRead = inputStream.read(readBuffer);
while (bytesRead != -1) {
readStr += new String(readBuffer).trim();
bytesRead = inputStream.read(readBuffer);
}
System (Java 2 Platform SE 5.0)
exit
public static void exit(int status)终止当前正在运行的 Java 虚拟机。参数用作状态码;根据惯例,非零的状态码表示异常终止。
该方法调用 Runtime 类中的 exit 方法。该方法永远不会正常返回。
调用 System.exit(n) 实际上等效于调用:
Runtime.getRuntime().exit(n)
参数:
status - 退出状态。
抛出:
SecurityException - 如果安全管理器存在并且其 checkExit 方法不允许以指定状态退出。
而且还有:
Runtime (Java 2 Platform SE 5.0)public void exit(int status)通过启动虚拟机的关闭序列,终止当前正在运行的 Java 虚拟机。此方法从不正常返回。可以将变量作为一个状态码;根据惯例,非零的状态码表示非正常终止。
虚拟机的关闭序列包含两个阶段。在第一个阶段中,会以某种未指定的顺序启动所有已注册的关闭挂钩(如果有的话),并且允许它们同时运行直至结束。在第二个阶段中,如果已启用退出终结,则运行所有未调用的终结方法。一旦完成这个阶段,虚拟机就会暂停。
如果在虚拟机已开始其关闭序列后才调用此方法,那么若正在运行关闭挂钩,则将无限期地阻断此方法。如果已经运行完关闭挂钩,并且已启用退出终结 (on-exit finalization),那么此方法将利用给定的状态码(如果状态码是非零值)暂停虚拟机;否则将无限期地阻断虚拟机。
System.exit 方法是调用此方法的一种传统而便捷的方式。
参数:
status - 终止状态。按照惯例,非零的状态码表明非正常终止。
抛出:
SecurityException - 如果安全管理器存在,并且其 checkExit 方法不允许存在指定的状态
所以总结起来:System.exit(n)中的n可以是0、1、2、3等等不同的数值,但最终非零的状态码表示异常终止,只有是0的时候是正常退出。
下面是JDK中的代码
public void exit(int status) {
SecurityManager security = System.getSecurityManager();
if (security != null) {
security.checkExit(status);
}
Shutdown.exit(status);
}
Shutdown中的静态方法exit
static void exit(int status) {
boolean runMoreFinalizers = false;
synchronized (lock) {
if (status != 0) runFinalizersOnExit = false;
switch (state) {
case RUNNING: /* 0, Initiate shutdown */
state = HOOKS;
break;
case HOOKS: /* 1, Stall and halt */
break;
case FINALIZERS:
if (status != 0) {
/* Halt immediately on nonzero status */
halt(status);
} else {
/* Compatibility with old behavior:
* Run more finalizers and then halt
*/
runMoreFinalizers = runFinalizersOnExit;
}
break;
}
}
if (runMoreFinalizers) {
runAllFinalizers();
halt(status);
}
synchronized (Shutdown.class) {
/* Synchronize on the class object, causing any other thread
* that attempts to initiate shutdown to stall indefinitely
*/
sequence();
halt(status);
}
}
这个应该是你手动停止的,不是程序自己出的异常,程序执行到该代码时退出,后续代码都不执行