详解java1.5新添特性------注解

详解java1.5新添特性------注解java

  在求职面试过程当中,被问到是否本身用过java注解以及本身实现过一个注解,当时就懵逼了,what's the f**k!
面试

    将来的开发模式都是基于注解的,JPA是基于注解的,Spring2.5以上都是基于注解的,Hibernate3.x之后也是基于注解的,如今的Struts2有一部分也是基于注解的了,注解是一种趋势数组

    废话不说直接实验开动起来:注解就是一个特殊的类,注解向开发工具或者编译器传递一种信息(官方的语言)ide

java中常见的注解工具

1.     @Override,子类覆写父类的方法;开发工具

2.     @SuppressWarnings(“deprecation”),压缩警告,忽略过期的警告;测试

3.     @Deprecated,方法过期;spa


package com.banyoukang.annotation;orm

    public class Test1 {对象

                public static void testSuppressWarn(){

                    System.runFinalizersOnExit(true);

                }

               @SuppressWarnings("deprecation")

                public static void testSuppressWarn2(){

                    System.runFinalizersOnExit(true);

                }

                @Override

                public String toString(){

                    return "banyoukang";

                }

                @Deprecated

                public static String testDeprecated(){

                    return "此注解说明这个方法已经废弃,或者过期了!";

                }

            public static void main(String[] args){

                testDeprecated();//这里使用testDeprecated方法就会显示这个方法已通过时

            }               

    /*

     * testSuppressWarn()方法和testSuppressWarn2()对比就能够发现,没有注解@SuppressWarnings("deprecation")

     * 的方法中使用了java过期的runFinalizersOnExit(boolean)方法,编译器会产生警告信息,而添加了注解的方法编译器则      *没有警告信息产生(便是注解的做用所在)

     */

}

经过上面的例子能够大体的看到注解的做用所在,接下来咱们本身实现一个注解,并提取相应的信息:

注解类

package com.banyoukang.annotation;


import java.lang.annotation.ElementType;

import java.lang.annotation.Retention;

import java.lang.annotation.RetentionPolicy;

import java.lang.annotation.Target;


@Target({ElementType.METHOD,ElementType.TYPE})

/*

 * Retention注解决定MyAnnotation注解的生命周期

   1.RetentionPolicy.SOURCE —— 这种类型的Annotations只在源代码级别保留,编译时就会被忽略

   2.RetentionPolicy.CLASS —— 这种类型的Annotations编译时被保留,在class文件中存在,但JVM将会忽略

   3.RetentionPolicy.RUNTIME —— 这种类型的Annotations将被JVM保留,因此他们能在运行时被JVM或其余使用反射机制的代码所读取和使用.

 */

@Retention(RetentionPolicy.RUNTIME)

public @interface MyAnnotation {

    //定义注解的属性

    String name();

    int age();

    boolean gender();

        //boolean gender() default true;这里能够为属性指定默认值,若是不指定的话,必定要传入

        //若是一个注解中有一个名称为value的属性,且你只想设置value属性(即其余属性都采用默认值或者你只有一个value属性),那么能够省略掉“value=”部分。

        //String value();

      //这里也能够定义高级属性,好比数组和枚举类型

}

测试类:

package com.banyoukang.annotation;


@MyAnnotation(name="班友康",age=20,gender=true)

public class MyAnnotationTest {

    public static void main(String[] args) {

//经过反射得到注解对应的实例对象,而后调用属性

        MyAnnotation annotation = MyAnnotationTest.class.getAnnotation(MyAnnotation.class);

        if(annotation.gender()){

            System.out.println("姓名:"+annotation.name()+",年龄:"+annotation.age()+",性别:男");

        }else{

            System.out.println("姓名:"+annotation.name()+",年龄:"+annotation.age()+",性别:女");

            }

        }

    }

能够看到注解更像是一种特殊的接口,注解的属性定义方式就和接口中定义方法的方式同样,而应用了注解的类能够认为是实现了这个特殊的接口

注:建议将代码复制过去本身运行一次看看,会对注解有比较好的认识。

相关文章
相关标签/搜索