定义注解
参考资料
http://www.jianshu.com/p/8d4cdb37e8f6
- [1]file->new module->选择java module 这里命名为annotation(随意)
- [2]src->new-> java class ->选择@Annotation 这里命名为LzfBindView
- [3]定义注解的示例
<!--
@Target说明了Annotation所修饰的对象范围:Annotation可被用于 packages、types(类、接口、枚举、Annotation类型)、类型成员(方法、构造方法、成员变量、枚举值)、方法参数和本地变量(如循环变量、catch参数)。在Annotation类型的声明中使用了target可更加明晰其修饰的目标。
作用:用于描述注解的使用范围(即:被描述的注解可以用在什么地方)
取值(ElementType)有:
1.CONSTRUCTOR:用于描述构造器 //用于构造方法
2.FIELD:用于描述域 //用于属性字段
3.LOCAL_VARIABLE:用于描述局部变量 //用于局部变量
4.METHOD:用于描述方法 //用于方法
5.PACKAGE:用于描述包 //用于包
6.PARAMETER:用于描述参数 //用于参数
7.TYPE:用于描述类、接口(包括注解类型) 或enum声明
-->
@Target(ElementType.FIELD)
<!--
@Retention定义了该Annotation被保留的时间长短:某些Annotation仅出现在源代码中,而被编译器丢弃;而另一些却被编译在class文件中;编译在class文件中的Annotation可能会被虚拟机忽略,而另一些在class被装载时将被读取(请注意并不影响class的执行,因为Annotation与class在使用上是被分离的)。使用这个meta-Annotation可以对 Annotation的“生命周期”限制。
作用:表示需要在什么级别保存该注释信息,用于描述注解的生命周期(即:被描述的注解在什么范围内有效)
取值(RetentionPoicy)有:
1.SOURCE:在源文件中有效(即源文件保留)
2.CLASS:在class文件中有效(即class保留)//class文件不可修改 一般使用这种方式 避免被用户修改了
3.RUNTIME:在运行时有效(即运行时保留)
-->
@Retention(RetentionPolicy.CLASS)
public @interface LzfBindView {
int value();
}
-[4]annotation的gradle
apply plugin: 'java'//java项目
dependencies {
compile fileTree(include: ['*.jar'], dir: 'libs')
//jdk版本 注意不要错了 or编译失败
sourceCompatibility = 1.7
targetCompatibility = 1.7
}