Annotation注解与butterknife

时间:2023-03-08 16:04:03

注解分为三种,一般来讲我们使用的是运行时会加载及能够反射读取的注解类型,

其他编译器生效的类型和编译后放入类文件而运行期不能加载解析的对我们没啥用。

所以从普通理解上来看,注解要配合着反射用就好了。

java有很多依赖注入框架,比如Spring,这类注解框架是很强大的,它们通过在运行

时读取注解实现注入,依赖和注入都需要依靠Java的反射机制,反射对于性能敏感

的Android来说是一个硬伤,所以这类注入框架一般用于JavaEE开发。

不过在butterknife中,其注解保留为class,RetentionPolicy.class,依赖注入,用

的是APT(Annotation Process Tool)在编译时生成辅助类,这些类继承特定父类或

实现特定接口,程序运行时的开销可以忽略不计。

注解相当于一种标记,在程序中加了注解就等于为程序打上了某种标记。程序可以利用

java的反射机制来了解你的类及各种元素上有无何种标记,针对不同的标记,就去做

相应的事件。标记可以加在包,类,字段,方法,方法的参数以及局部变量上。

但凡Annotation起作用的场合都是有一个执行机制/调用者通过反射获得了这个元数据

然后根据它采取行动。

如果只有value属性!可以不写属性名和等于号,直接写值即可!

注解的作用:

1.生成文档。最常见的,java最早提供的注解,常用的有@see,@param,@return

2.跟踪代码依赖性,实现替代配置文件功能。注解配置。

3.在编译时进行格式检查。如@override放在方法前,如果这个方法不是覆盖了超类

方法,则编译时就能检查出。

注意在使用butterknife的时候,

在8.0版本,

需要添加apt工具,

在project的build文件添加,

classpath 'com.neenbedankt.gradle.plugins:android-apt:1.8'

在module的build文件的最上部添加,

apply plugin: 'com.neenbedankt.android-apt'

依赖dependencies那里需要填上,

compile 'com.jakewharton:butterknife:8.0.1'

apt 'com.jakewharton:butterknife-compiler:8.0.1'

这样才能通过编译,如果不添加apt的话。

@BindView(R.id.click1)

Button b1;

在下面直接使用的话,会出现null指针异常。

另外注意不能用private或者static

@BindViews({R.id.click2,R.id.click3})

Button[] b;// 这里需要用list或者array

在下面用的话,

b[0].setOnClickListener(new View.OnClickListener(){

@Override

public void onClick(View v) {

Toast.makeText(MainActivity.this,"点击了2",Toast.LENGTH_SHORT).show();

}

});

    b[1].setOnClickListener(new View.OnClickListener(){
@Override
public void onClick(View v) {
Toast.makeText(MainActivity.this,"点击了3",Toast.LENGTH_SHORT).show();
}
});

@BindString(R.string.app2)

String app2;

绑定预设的字符串以及color、dimen,drawable等。可以节省大量代码的编写。

凡是跟view相关需要findViewById的都可以用这个,包括lists,

不过这里需要用到Action和Setter

还有监听绑定,甚至可以分组一起绑定。

在碎片中注意在onDestroyView中需要unbind方法中取消绑定,

这里在Unbinder中有解绑实例。

即使使用butterknife,也可以使用findById来找,可以减少代码