ai文件怎么转曲(ai文件转曲后怎么改文字)
6442023-12-05
今天给各位分享java怎么避免死锁的知识,其中也会对java死锁的解决办法进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!
本文目录
Java的异常处理机制是Java语言的重要组成部分,要想理解Java异常处理机制就先要从Java异常处理的概念以及方式开始。在文章开始之前,我先给大家看一个程序:
如果你能清晰的描述出这个程序的运行结果,那么这篇文章就可以不用读了,否则就仔细的读一下。
Java异常的概念是程序在执行过程中遇到不可预见的错误,这个概念中有两点需要关注,一点是“程序在运行过程中”,这说明程序本身的语法是没有问题的,另一点是“不可预见的错误”,这就说明异常的产生具有一定的偶然性。
Java的异常处理方式有两个大的机制一个是try-catch机制,另一个是throws机制。try-catch机制简单的说就是捕获并处理异常,try-catch的用法非常灵活,既可以分层处理异常,也可以嵌套处理异常,看一个例子:
当try体中产生异常的时候,系统就会跳转到catch体进行异常处理,在这个例子中一个大的try-catch中还嵌套了一个小的try-catch体来单独处理一部分语句的异常,同时外部的try体还定义了两个catch体与之匹配,分别处理不同的异常。注意,在排列的时候要注意顺序,因为catch在处理异常的时候是就近匹配的,当程序匹配到一个catch体之后就不再继续往下匹配了,所以一定要把Exception异常放到后面,否则其他的catch体就起不到作用了。
接下来就要看一下throws和throw这两个关键字的作用了,简单的说throws是声明异常,而throw是抛出异常对象。看一个例子:
注意throws的位置在方法的声明处,而throw则在方法体内,throws后面跟的是异常的类型,而throw后面跟的则是异常的对象。注意在catch体内的throw语句虽然也会抛出一个异常,但是此处的异常并不会抛出到方法外部,这是一个需要注意的地方,看一个例子:
这个例子我们可以看到Foo方法并没有声明异常,程序依然可以运行,但是程序的第20行语句并不会得到执行,原因是程序在第11行由于throwe而退出了。
通常情况下,当一个方法声明异常时,所有调用这个方法的方法要么处理这个异常,要么继续声明,不能视而不见,简单的说,就是异常在传递的过程中不能无缘无故的消失,这是保证程序健壮性的一个非常重要的机制。
接下来就是自定义异常了,自定义异常有三个特点,分别是自己定义、自己抛出、自己处理,系统并不会抛出用户的自定义异常,看一个例子:
自定义异常在实际的使用中还是比较常见的。
当然,在使用try-catch的过程中还有一个重要的结构就是finally体,finally体的作用是无论try体是否有异常产生,finally体的内容都会得到执行,当然也有例外,看一个例子:
这个例子中在try体内调用了exit()方法,导致系统直接退出了,从而略过了fianlly体,这是一个需要注意的地方,通常情况下,finally体用于资源的回收处理。
接下来说一下断言(assert)的使用,在jdk1.4以后出现了断言,断言可以在程序中为程序员验证各种假设,可以说断言是对异常处理的一种辅助,看一个例子:
断言的使用在做测试的时候还是比较常见的。
虽然Java的异常处理看起来比较简单,但是要想把异常处理的机制搞清楚还是需要一个过程的,我使用Java的时间比较久,我在头条上也写了关于学习Java的系列文章,想学习Java的朋友可以关注我,相信一定会有所收获,如果有Java开发方面的问题,也可以咨询我。
谢谢!
首先,我们知道Java有3种抛出异常的形式:throw(执行的时候一定抛出某种异常对象),throws(出现异常的可能性,不一定会发生),系统自动抛异常。
throw用在一个语句抛出异常的时候,throw(aninstanceofexceptionclass)比如一个方法/函数里,try{…}catch(Exceptione){thrownewArithmeticException(“XXX”);}finally{…};
throws则是用在声明方法可能抛出异常的时候,throw(exceptionclass)比如publicintdivision(intx,inty)throwsArithmeticException{…};
系统自动抛异常则是当程序语句出现逻辑错误,主义错误或类型转换错误的时候,系统自动抛出异常,比如inta=5;intb=0;c=a/b;这个时候移动会自动抛出ArithmeticException。
什么是异常异常,顾名思义,就是有异于正常状态,有错误发生。而这错误会阻止Java当前函数方法的运行。
那么Java里面异常的体系是怎么样的呢?
1.Java里面所有不正常类都继承于Throwable类;而Throwable类包括2类:Error类和Exception类。
2.Error类包括虚拟机错误(VirtualMachineError)和线程死锁(ThreadDeath)。
3.Exception类则是我们在说的异常;包括运行时异常(RuntimeException)和检查异常;这里的异常通常是编码,环境,用户操作输入出现了问题。
4.运行时异常(RuntimeException)包括以下4种异常:空指针异常(NullPointerException),数组下标越界异常(ArrayIndexOutOfBoundsException),类型转换异常(ClassCastException),算术异常(ArithmeticException)。
空指针异常:
数组下标越界异常:
类型转换异常:
算术异常:
5.最后剩下的检查异常则是剩下各种异常的集合;这里发生异常的原因有很多,文件异常(IOException),连接异常(SQLException)等等;和运行时异常不同的是,这里的异常我们必须手动在代码里添加try…catch…(finally…)语句来捕获处理。
今天又了解学习到了一些具体的额外的异常:
Throw抛出异常详细过程和throws声明方法可能会发生异常不同,throw语句则是直接抛出一个异常。
前面有提到,throw(aninstanceofexceptionclass),这里的一个exception类的实例其实也可以说是一个ExceptionObject(Throwable类或则其子类的对象;也可以是自定义的继承自Throwable的直接或间接的异常类)。如果,我们用了thrownewString(“异常XXX”);则会在编译的时候报错,因为String类并不是Throwable类的子类。
接着让我们回到怎么用throw语句的阶段。
一般我们有两种方式来用throw:直接在某处会发生异常的地方用throw语句或则用try…catch…finally…语句来捕获处理异常和关闭释放资源。
首先是第一种,直接在某处会发生异常的地方用throw语句;这是一种主动的方法,主动抛出异常去处理。
而第二种,用try…catch…finally…语句来捕获处理异常和关闭释放资源则是被动的方法。try里面放入可能会发生异常的语句块,如果在运行期间遇到了异常,则会交给catch来处理异常(catch可以是多个,处理不同的异常),finally则是无论有没有异常发生,只要加上了就会运行。
首先我们来看第一种方法的函数:
我们的intc=4/2,其实是正确的;但是我们的throw语句主动抛出了异常,那么程序就会到catch里面找有没有这个异常,有的话进行处理。所以我们要主动抛异常的话,要很确信这个代码一定会发生异常且后期不太会去变动了(最好放在if条件语句里)。所以我们得到的结果如下:
接着我们来看第二种方法。我们一开始先测正确的,只是把主动抛出异常语句给注释掉:
因为try里面的语句块没有异常,所以只执行了try和finally里面的语句块。运行的结果如下:
我们接着来测当try里面的语句块有异常,且没有主动抛出异常的时候,try会不会捕捉到异常吧:
得到的结果如下,会去处理异常和执行finally里面的语句块:
最后深入理解一点try里面的异常触发会逐层向上的这个概念。在我们try语句里主动/被动抛出异常的时候,程序会调向调用者程序(上面的例子里就是我们自己这个函数;但有的时候我们会在try语句里执行别的函数比如B,这个函数B里我们假如触发了异常,它会调向try语句所在的函数A),寻找和它相匹配的catch语句,执行catch语句里面相应的异常处理程序;但假如没有找到相匹配的catch语句,那么它会再转向上一层的调用程序…这样逐层向上,直到最外层的异常程序终止程序并打印出stacktrace。
参考资料
rollbar.com/guides/java…www.javatpoint.com/throw-keywo…www.geeksforgeeks.org/throw-throw…本文分享自华为云社区《Java-throw异常详解以及过程-云社区-华为云》,作者:gentle_zhou。
数据库死锁通常出现在表级及行级锁定相关的语句。如显式锁定、更新等操作。通常在数据库(SQL)的说明中都有标明相关的(隐式)锁定操作。所以必须要熟记相关的SQL操作过程。如果程序中使用了线程,就要小心线程间竞争资源,或对锁定表、记录的操作时序。
多线程编程是一门学问,只能通过不断学习、练习、及习惯,来渐渐掌握体会。
1、尽量使用tryLock(longtimeout,TimeUnitunit)的方法(ReentrantLock、ReentrantReadWriteLock),设置超时时间,超时可以退出防止死锁。
2、尽量使用java.util.concurrent(jdk1.5以上)包的并发类代替手写控制并发,比较常用的是ConcurrentHashMap、ConcurrentLinkedQueue、AtomicBoolean等等,实际应用中java.util.concurrent.atomic十分有用,简单方便且效率比使用Lock更高。
3、尽量降低锁的使用粒度,尽量不要几个功能用同一把锁。
4、尽量减少同步的代码块。
百度搜索圈T社区免费行业视频教程
www.aiquanti.com
好了,本文到此结束,如果可以帮助到大家,还望关注本站哦!