7.5.1注解的定义与反射的调用
2011-01-29 11:40
239 查看
h4 { margin-top: 0.49cm; margin-bottom: 0.51cm; line-height: 156%; page-break-inside: avoid; }h4.western { font-family: "Arial",sans-serif; font-size: 14pt; }h4.cjk { font-family: "黑体","SimHei"; font-size: 14pt; }h4.ctl { font-family: "DejaVu Sans"; font-size: 14pt; }p { margin-bottom: 0.21cm; }a:link { color: rgb(0, 0, 255); }
注解的应用结构图
:
元注解:对注解进行注解
注解对注解类服务
注解的定义 :
注解的定义和定义接口相似
只是在interface
前面加一个@
public
@interface
ItcastAnnotaion
在
MyEclipse
里面生成注解
new
-- annotation
RetentionPolicy
注解的生命周期:
源代码阶段 仅仅在编译前存在
@Retention
(RetentionPolicy.
SOURCE)
class
文件阶段
仅仅在编译成。Class
文件后
,运行在内存前存在 (
默认
)@Retention
(RetentionPolicy.
CLASS)
内存中的字节码阶段 在内存中存在
即在类运行的时候存在 @Retention
(RetentionPolicy.
RUNTIME)
例子 下面是创建一个新的注解
并将生命周期设置为在内存中存在
@Retention
(RetentionPolicy.
RUNTIME
)
public
@interface
ItcastAnnotaion
{
}
注解的作用域
@Target
()
是用来定义注解的作用域的注解
参数
:
如果要定义为在类和方法中都能使用此注解
:
@Target
({ElementType.
TYPE
,ElementType.
METHOD
})
{}
代表是一个数组
TYPE
是代表
Type
接口
为什么定义为在类中能使用是用
Type
接口,而不是使用的
Class?
答:因为在
1.5
以后
开发者发现像
Interface
enum
等都和
Class
平级
需要一个东西来描述他们 所以 就开发出来了
Type
接口
类的父类继承了
Class
类
而
Class
类实现了
Type
接口
Interface
enum
也实现了
Type
接口
所以 这里的
TYPE
包括了
class
Interface enum
例子
定义一个注解 生命周期为运行期 作用域为在类中和方法中
@Retention
(RetentionPolicy.
RUNTIME
)
@Target
({ElementType.
TYPE
,ElementType.
METHOD
})
public
@interface
ItcastAnnotaion
{
}
注解的使用及处理
模拟编译器对注解进行处理
只要在类或方法里面使用了注解,在此类中就会存在一个注解所对应的注解
jdk
会判断你使用了那个注解
下面是模拟
java
编译器判断此类中是否存在某一个注解
:
注解的使用
: 直接在类或方法上面写上
@
注解名就行了
if
(AnnotaionTest.
class
.isAnnotationPresent(
ItcastAnnotaion
.
class
)){
//
得到
ItcastAnnotaion
这个注解类
ItcastAnnotaion
annotaion =
(
ItcastAnnotaion
)AnnotaionTest.
class
.getAnnotation(
ItcastAnnotaion
.
class
);
System.
out
.println(annotaion);
}
注解的应用结构图
:
元注解:对注解进行注解
注解对注解类服务
注解的定义 :
注解的定义和定义接口相似只是在interface
前面加一个@
public
@interface
ItcastAnnotaion
在
MyEclipse
里面生成注解
new
-- annotation
RetentionPolicy
注解的生命周期:
源代码阶段 仅仅在编译前存在
@Retention
(RetentionPolicy.
SOURCE)
class
文件阶段
仅仅在编译成。Class
文件后
,运行在内存前存在 (
默认
)@Retention
(RetentionPolicy.
CLASS)
内存中的字节码阶段 在内存中存在
即在类运行的时候存在 @Retention
(RetentionPolicy.
RUNTIME)
例子 下面是创建一个新的注解
并将生命周期设置为在内存中存在
@Retention
(RetentionPolicy.
RUNTIME
)
public
@interface
ItcastAnnotaion
{
}
注解的作用域
@Target
()
是用来定义注解的作用域的注解
参数
:
ANNOTATION_TYPE 注释类型声明 |
CONSTRUCTOR 构造方法声明 |
FIELD 字段声明(包括枚举常量) |
LOCAL_VARIABLE 局部变量声明 |
METHOD 方法声明 |
PACKAGE 包声明 |
PARAMETER 参数声明 |
TYPE 类、接口(包括注释类型)或枚举声明 |
:
@Target
({ElementType.
TYPE
,ElementType.
METHOD
})
{}
代表是一个数组
TYPE
是代表
Type
接口
为什么定义为在类中能使用是用
Type
接口,而不是使用的
Class?
答:因为在
1.5
以后
开发者发现像
Interface
enum
等都和
Class
平级
需要一个东西来描述他们 所以 就开发出来了
Type
接口
类的父类继承了
Class
类
而
Class
类实现了
Type
接口
Interface
enum
也实现了
Type
接口
所以 这里的
TYPE
包括了
class
Interface enum
例子
定义一个注解 生命周期为运行期 作用域为在类中和方法中
@Retention
(RetentionPolicy.
RUNTIME
)
@Target
({ElementType.
TYPE
,ElementType.
METHOD
})
public
@interface
ItcastAnnotaion
{
}
注解的使用及处理
模拟编译器对注解进行处理
只要在类或方法里面使用了注解,在此类中就会存在一个注解所对应的注解
jdk
会判断你使用了那个注解
下面是模拟
java
编译器判断此类中是否存在某一个注解
:
注解的使用
: 直接在类或方法上面写上
@
注解名就行了
if
(AnnotaionTest.
class
.isAnnotationPresent(
ItcastAnnotaion
.
class
)){
//
得到
ItcastAnnotaion
这个注解类
ItcastAnnotaion
annotaion =
(
ItcastAnnotaion
)AnnotaionTest.
class
.getAnnotation(
ItcastAnnotaion
.
class
);
System.
out
.println(annotaion);
}
相关文章推荐
- 注解的定义与反射调用
- 注解的定义和反射调用
- Java基础---Java---基础加强---内省的简单运用、注解的定义与反射调用、 自定义注解及其应用、泛型及泛型的高级应用、泛型集合的综合
- Java基础---Java---基础加强---内省的简单运用、注解的定义与反射调用、 自定义注解及其应用、泛型及泛型的高级应用、泛型集合的综合
- 注解的定义与反射调用
- 34_注解的定义与反射调用
- 33了解和入门注解的应用34 注解的定义与反射调用35为注解增加各种属性
- 注解的定义与反射调用
- 注解的定义与反射调用
- java反射--注解的定义与运用以及权限拦截
- java反射--注解的定义与运用以及权限拦截
- MyBatis+Spring在注解@Autowried后通过反射的方式调用方法获取注入的Service或DAO对象为空
- 黑马程序员---注解与反射的调用以及添加各种属性
- 注解:认识注解、注解的分类、注解的生命周期、自定义注解及反射调用、为注解添加属性
- 自定义注解(2)—定义和使用(利用反射获取)
- 自定义注解以及反射得到当前的调用方法
- 利用反射调用注解
- C# 反射详解:定义、创建对象、调用实例方法及静态方法
- 注解:认识注解、注解的分类、注解的生命周期、自定义注解及反射调用、为注解添加属性
- CodeDom系列--事件(event)定义和反射调用