189 8069 5689

java代码阻断 java阻止

java项目中运行错误

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语句声明该方法可能抛出的异常

重写方法需要抛出与原方法所抛出异常类型一致异常或不抛出异常

java通过串口接收数据,不正常。求大神指导

不要使用inputStream.available(),如果我没有记错的话,available返回的是没有被阻断的字节数(已经被缓冲的内容),可以尝试read(byte b[])方法,然后通过返回值是否-1来判断,如下。

int bytesRead = inputStream.read(readBuffer);

while (bytesRead != -1) {

readStr += new String(readBuffer).trim();

bytesRead = inputStream.read(readBuffer);

}

java代码中,System.exit(1); 有什么作用?不是抛出异常之后就不会往下执行了吗?

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);

}

}

这个应该是你手动停止的,不是程序自己出的异常,程序执行到该代码时退出,后续代码都不执行


本文题目:java代码阻断 java阻止
文章转载:http://cdxtjz.cn/article/dodooep.html

其他资讯