IOC框架设计----Butterknife

2024-04-20 19:48
文章标签 设计 框架 ioc butterknife

本文主要是介绍IOC框架设计----Butterknife,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

什么是IOC?
核心思想就是:
IOC是原来由程序代码中主动获取的资源,转变由第三方获取,并使原来的代码被动接收的方式,以达到解耦的效果,称为控制翻转。
举个生活中的例子:
你–>穿衣服—>出门 (ioc以前)
你—》一个眼神—>女朋友给你拿衣服,再给你穿上—>出门 (ioc以后)

采用APT注解处理器,替我们写代码。
在这里插入图片描述
app、注解、注解处理器之间的关系:
在这里插入图片描述
注解处理器写法:
1、AnnotationCompiler 继承 AbstractProcessor 重写process方法

public class AnnotationCompiler extends AbstractProcessor {

2、类上加注解@AutoService(processor.class)

@AutoService(Processor.class)
public class AnnotationCompiler extends AbstractProcessor {

3、类里 定义一个用于生成文件的对象
Filer filer; 可以直接get到filer

 //1.定义一个用于生成文件的对象Filer filer;@Overridepublic synchronized void init(ProcessingEnvironment processingEnvironment) {super.init(processingEnvironment);filer=processingEnvironment.getFiler();}

定义一个当前APT处理所有模块中哪些注解

 //2.需要确定当前APT处理所有模块中哪些注解@Overridepublic Set<String> getSupportedAnnotationTypes() {Set<String> types=new HashSet<>();types.add(BindView.class.getCanonicalName());
//        types.add(Override.class.getCanonicalName());return types;}

支持的JDK的版本

 }//3.支持的JDK的版本@Overridepublic SourceVersion getSupportedSourceVersion() {return SourceVersion.latestSupported();}

4、在process方法里开始写文件:
通过roundEnviroment,获取到所有activity中用了我们指定注解的元素。


/*** 在这个方法中,我们去生成IBinder的实现类* @param set* @param roundEnvironment* @return*/@Overridepublic boolean process(Set<? extends TypeElement> set, RoundEnvironment roundEnvironment) {//得到程序中所有写了BindView注解的元素的集合
//类元素(TypeElement)
//可执行元素(ExecutableElement)
//属性元素(VariableElement)Set<? extends Element> elementsAnnotatedWith = roundEnvironment.getElementsAnnotatedWith(BindView.class);

定义一个map <activity名,list<控件类型>>

 //定义一个MAP用来分类Map<String, List<VariableElement>> map=new HashMap<>();
 //开始分类存入MAP中for (Element element : elementsAnnotatedWith) {VariableElement variableElement=(VariableElement)element;//获取activity的名字String activityName=variableElement.getEnclosingElement().getSimpleName().toString();List<VariableElement> elementList=map.get(activityName);//如果等于空,就新创建一个listif(elementList==null){elementList=new ArrayList<>();map.put(activityName,elementList);}//创建了就add进去elementList.add(variableElement);}

运行到这就已经完成了分类工作

准备开始写文件

             //        public class MainActivity_ViewBinding implements IBinder<com.example.dn_butterknife.MainActivity>{writer.write("public class "+activityName+"_ViewBinding implements IBinder<"+packageName+"."+activityName+">{\n");//            @Overridewriter.write("@Override\n");//            public void bind(com.example.dn_butterknife.MainActivity target) {writer.write("public void bind("+packageName+"."+activityName+" target){\n");// target.tvText=(android.widget.TextView)target.findViewById(2131165325);for (VariableElement variableElement : elementList) {//获取控件的名字String variableName=variableElement.getSimpleName().toString();//获取IDint id=variableElement.getAnnotation(BindView.class).value();//获取控件的类型TypeMirror typeMirror=variableElement.asType();writer.write("target."+variableName+"=("+typeMirror+")target.findViewById("+id+");\n");}writer.write("\n}}");}catch(Exception e){e.printStackTrace();}finally{if(writer!=null){try {writer.close();} catch (IOException e) {e.printStackTrace();}}}}}

完整代码:

/*** 这个类就是APT*/
@AutoService(Processor.class)
public class AnnotationCompiler extends AbstractProcessor {//1.定义一个用于生成文件的对象Filer filer;@Overridepublic synchronized void init(ProcessingEnvironment processingEnvironment) {super.init(processingEnvironment);filer=processingEnvironment.getFiler();}//2.需要确定当前APT处理所有模块中哪些注解@Overridepublic Set<String> getSupportedAnnotationTypes() {Set<String> types=new HashSet<>();types.add(BindView.class.getCanonicalName());
//        types.add(Override.class.getCanonicalName());return types;}//3.支持的JDK的版本@Overridepublic SourceVersion getSupportedSourceVersion() {return SourceVersion.latestSupported();}/*** 在这个方法中,我们去生成IBinder的实现类* @param set* @param roundEnvironment* @return*/@Overridepublic boolean process(Set<? extends TypeElement> set, RoundEnvironment roundEnvironment) {//得到程序中所有写了BindView注解的元素的集合//类元素(TypeElement)//可执行元素(ExecutableElement)//属性元素(VariableElement)Set<? extends Element> elementsAnnotatedWith=roundEnvironment.getElementsAnnotatedWith(BindView.class);//定义一个MAP用来分类Map<String, List<VariableElement>> map=new HashMap<>();//开始分类存入MAP中for (Element element : elementsAnnotatedWith) {VariableElement variableElement=(VariableElement)element;//获取activity的名字String activityName=variableElement.getEnclosingElement().getSimpleName().toString();List<VariableElement> elementList=map.get(activityName);if(elementList==null){elementList=new ArrayList<>();map.put(activityName,elementList);}elementList.add(variableElement);}//运行到这就已经完成了分类工作if(map.size()>0){//开始写入文件Writer writer=null;//每一个activity都要生成一个对应的文件Iterator<String> iterator = map.keySet().iterator();while(iterator.hasNext()){String activityName=iterator.next();List<VariableElement> elementList=map.get(activityName);//获取包名TypeElement enclosingElement=(TypeElement)elementList.get(0).getEnclosingElement();String packageName=processingEnv.getElementUtils().getPackageOf(enclosingElement).toString();try{//生成文件//包名.MainActivity_ViewBindingJavaFileObject sourceFile = filer.createSourceFile(packageName + "." + activityName + "_ViewBinding");writer=sourceFile.openWriter();//        package com.example.dn_butterknife;writer.write("package "+packageName+";\n");//        import com.example.dn_butterknife.IBinder;writer.write("import "+packageName+".IBinder;\n");//        public class MainActivity_ViewBinding implements IBinder<com.example.dn_butterknife.MainActivity>{writer.write("public class "+activityName+"_ViewBinding implements IBinder<"+packageName+"."+activityName+">{\n");//            @Overridewriter.write("@Override\n");//            public void bind(com.example.dn_butterknife.MainActivity target) {writer.write("public void bind("+packageName+"."+activityName+" target){\n");// target.tvText=(android.widget.TextView)target.findViewById(2131165325);for (VariableElement variableElement : elementList) {//获取控件的名字String variableName=variableElement.getSimpleName().toString();//获取IDint id=variableElement.getAnnotation(BindView.class).value();//获取控件的类型TypeMirror typeMirror=variableElement.asType();writer.write("target."+variableName+"=("+typeMirror+")target.findViewById("+id+");\n");}writer.write("\n}}");}catch(Exception e){e.printStackTrace();}finally{if(writer!=null){try {writer.close();} catch (IOException e) {e.printStackTrace();}}}}}return false;}
}

这篇关于IOC框架设计----Butterknife的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/921166

相关文章

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

怎么让1台电脑共享给7人同时流畅设计

在当今的创意设计与数字内容生产领域,图形工作站以其强大的计算能力、专业的图形处理能力和稳定的系统性能,成为了众多设计师、动画师、视频编辑师等创意工作者的必备工具。 设计团队面临资源有限,比如只有一台高性能电脑时,如何高效地让七人同时流畅地进行设计工作,便成为了一个亟待解决的问题。 一、硬件升级与配置 1.高性能处理器(CPU):选择多核、高线程的处理器,例如Intel的至强系列或AMD的Ry

cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个?

跨平台系列 cross-plateform 跨平台应用程序-01-概览 cross-plateform 跨平台应用程序-02-有哪些主流技术栈? cross-plateform 跨平台应用程序-03-如果只选择一个框架,应该选择哪一个? cross-plateform 跨平台应用程序-04-React Native 介绍 cross-plateform 跨平台应用程序-05-Flutte

Spring框架5 - 容器的扩展功能 (ApplicationContext)

private static ApplicationContext applicationContext;static {applicationContext = new ClassPathXmlApplicationContext("bean.xml");} BeanFactory的功能扩展类ApplicationContext进行深度的分析。ApplicationConext与 BeanF

基于51单片机的自动转向修复系统的设计与实现

文章目录 前言资料获取设计介绍功能介绍设计清单具体实现截图参考文献设计获取 前言 💗博主介绍:✌全网粉丝10W+,CSDN特邀作者、博客专家、CSDN新星计划导师,一名热衷于单片机技术探索与分享的博主、专注于 精通51/STM32/MSP430/AVR等单片机设计 主要对象是咱们电子相关专业的大学生,希望您们都共创辉煌!✌💗 👇🏻 精彩专栏 推荐订阅👇🏻 单片机

数据治理框架-ISO数据治理标准

引言 "数据治理"并不是一个新的概念,国内外有很多组织专注于数据治理理论和实践的研究。目前国际上,主要的数据治理框架有ISO数据治理标准、GDI数据治理框架、DAMA数据治理管理框架等。 ISO数据治理标准 改标准阐述了数据治理的标准、基本原则和数据治理模型,是一套完整的数据治理方法论。 ISO/IEC 38505标准的数据治理方法论的核心内容如下: 数据治理的目标:促进组织高效、合理地

ZooKeeper 中的 Curator 框架解析

Apache ZooKeeper 是一个为分布式应用提供一致性服务的软件。它提供了诸如配置管理、分布式同步、组服务等功能。在使用 ZooKeeper 时,Curator 是一个非常流行的客户端库,它简化了 ZooKeeper 的使用,提供了高级的抽象和丰富的工具。本文将详细介绍 Curator 框架,包括它的设计哲学、核心组件以及如何使用 Curator 来简化 ZooKeeper 的操作。 1

SprinBoot+Vue网络商城海鲜市场的设计与实现

目录 1 项目介绍2 项目截图3 核心代码3.1 Controller3.2 Service3.3 Dao3.4 application.yml3.5 SpringbootApplication3.5 Vue 4 数据库表设计5 文档参考6 计算机毕设选题推荐7 源码获取 1 项目介绍 博主个人介绍:CSDN认证博客专家,CSDN平台Java领域优质创作者,全网30w+

【Kubernetes】K8s 的安全框架和用户认证

K8s 的安全框架和用户认证 1.Kubernetes 的安全框架1.1 认证:Authentication1.2 鉴权:Authorization1.3 准入控制:Admission Control 2.Kubernetes 的用户认证2.1 Kubernetes 的用户认证方式2.2 配置 Kubernetes 集群使用密码认证 Kubernetes 作为一个分布式的虚拟

Spring Framework系统框架

序号表示的是学习顺序 IoC(控制反转)/DI(依赖注入): ioc:思想上是控制反转,spring提供了一个容器,称为IOC容器,用它来充当IOC思想中的外部。 我的理解就是spring把这些对象集中管理,放在容器中,这个容器就叫Ioc这些对象统称为Bean 用对象的时候不用new,直接外部提供(bean) 当外部的对象有关系的时候,IOC给它俩绑好(DI) DI和IO