Java SE 第六十九,七十,一,二,三,四,五 讲 Annotation详解异常详解自定义异常,异常笔试面试常见问题深度剖析.
1.Java注解(Annotation):
①Override注解表示子类要重写(override)父类对应的方法.
②Deprecated注解表示方法不建议被使用的.
③@SuppressWarnings注解表示抑制警告.
2.自定义注解:当注解中的属性名为value时,在对其赋值是可以不指定属性的名称而直接写上属性值即可;出了value以外的其他值都需要使用name = value这种赋值方式,即明确指定给谁赋值.
3.当我们使用@interface关键字定义一个注解时,该注解隐含地继承了java.lang.annotation.Annotation接口;如果我们定义了一个接口,并且让该接口继承自Annotation,那么所定义的接口依然还是接口不是注解;Annotation本身是接口而不是注解.可以与Enum类比.
4.java.lang.annotation.Retention形态可以在您定义Annotation形态时,只是编译程序该如何对待您的自定义的Annotation形态.
5.使用RetentionPolicy
6.JUnit(为3.8,4.x):
Keep the bar green keep the code clean
7.没有反射,很多框架就不存在了.
8.JUnit4的执行的一般流程:
a)首先获得带测试类所对应的Class对象.
b)然后通过该Class对象获得当前类中所有public方法所对应的Method数组,
c)遍历Method数组,取得每一个Method对象.
d)调用每个Method对象的isAnnotationPresent(Test.class)方法,判断该方法是否被Test注解所修饰.
e)如果该方法返回true,那么调用method.invoke()方法去执行该方法,否则不执行.
9.单元测试不是为了证明你是对的,而是证明你没有错误.
10.Writing Secure Code(编写安全的代码):Input is evil.
11.异常(Exception)
12.Java中异常分为两大类:
①Checked exception(非 Runtime Exception)
②Unchecked exception(Runtime Exception)
13.Java中所有异常都会直接或间接继承自Exception.
14.Runtime exception类直接结成自Exception类,她叫做运行时异常,Java中所有的运行时异常都会直接或间接地继承自RuntimeException.
15.Java中凡是继承自Exception而不继承自RuntimeException的类都是CheckedException(非运行时异常)
16.异常处理的一般结构:
try
{
//可能会发生异常的代码
}
catch(Except e)
{
//异常处理
}
finally
{
//一定会执行的代码
}
无论程序是否出现异常,finally块中的代码一定会被执行的.
try:
17:对于非运行时异常(checked exception),必须要对其进行处理,处理方式有两种:第一种是使用Try..catch..finally进行处理;第二种是在调用该会产生异常的方法所在的方法声明throws Exception
18.对于运行时异常可以不对其处理,也可以对其处理,推荐不处理.
19.NullPointerException是空指针异常,出现该异常的原因为某个指针为null,但你却调用了它的某个方法,这是就会出现该异常.
20.所以自定义异常,通常就是定义了一个继承自Exception类的子类,那么这个类就是一个自定义异常类.通常情况下,我们都会直接继承自Exception类,一般不会继承某个运行时异常类.
21.自定义异常.
注意捕获多个异常时的顺序
22.我们可以使用多个catch语句来捕获异常,这是需要将父类型的catch块放到子类型的catch块后,这样才能保证后续的catch可能执行,否则子类型的catch将永远无法到达,Java编译器会报编译错误.如果多个catch块为独立的,不存在继承关系,那么谁先后都是可以的.
23.如果try语句中存在return语句,那么首先也需要将finally块中的代码执行完毕,然后方法返回.
24.exit(0)退出当前的虚拟机.如果try块中存在System.exit(0)语句,那么就不会执行finally块中的代码,因为System.exit(0)会终止当前运行的Java虚拟机,程序会在虚拟机终止前结束执行.