0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
会员中心
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

标签 > Processor

Processor

+关注 0人关注

Processor的中文意思是:处理器,Intel Processor即Intel 系列处理器。是一块超大规模的集成电路,是一台计算机的运算核心(Core)和控制核心( Control Unit)。

文章: 1
视频: 15
浏览: 30778
帖子: 9

Processor简介

  Processor的中文意思是:处理器,Intel Processor即Intel 系列处理器。

  中央处理器(CPU,Central Processing Unit)是一块超大规模的集成电路,是一台计算机的运算核心(Core)和控制核心( Control Unit)。

  主要分为两大类型:

  Intel系列处理器和AMD系列处理器。

Processor百科

  Processor的中文意思是:处理器,Intel Processor即Intel 系列处理器。

  中央处理器(CPU,Central Processing Unit)是一块超大规模的集成电路,是一台计算机的运算核心(Core)和控制核心( Control Unit)。

  主要分为两大类型:

  Intel系列处理器和AMD系列处理器。

  

  

  一小时搞明白注解处理器(Annotation Processor Tool)

  Java中的注解是个很神奇的东西,还不了解的可以看下一小时搞明白自定义注解(Annotation)。现在很多Android的库都用使用注解实现的,比如ButterKnife,我们不防也来学习一下,学完注解处理器,我们尝试写一个简单的类似ButterKnife的东西来绑定控件。

  什么是注解处理器?

  注解处理器是(Annotation Processor)是javac的一个工具,用来在编译时扫描和编译和处理注解(Annotation)。你可以自己定义注解和注解处理器去搞一些事情。一个注解处理器它以Java代码或者(编译过的字节码)作为输入,生成文件(通常是java文件)。这些生成的java文件不能修改,并且会同其手动编写的java代码一样会被javac编译。看到这里加上之前理解,应该明白大概的过程了,就是把标记了注解的类,变量等作为输入内容,经过注解处理器处理,生成想要生成的java代码。

  处理器AbstractProcessor

  处理器的写法有固定的套路,继承AbstractProcessor。如下:

  public class MyProcessor extends AbstractProcessor {

  @Override

  public synchronized void init(ProcessingEnvironment processingEnv) {

  super.init(processingEnv);

  }

  @Override

  public Set《String》 getSupportedAnnotationTypes() {

  return null;

  }

  @Override

  public SourceVersion getSupportedSourceVersion() {

  return SourceVersion.latestSupported();

  }

  @Override

  public boolean process(Set《? extends TypeElement》 annotations, RoundEnvironment roundEnv) {

  return true;

  }

  }

  init(ProcessingEnvironment processingEnv) 被注解处理工具调用,参数ProcessingEnvironment 提供了Element,Filer,Messager等工具

  getSupportedAnnotationTypes() 指定注解处理器是注册给那一个注解的,它是一个字符串的集合,意味着可以支持多个类型的注解,并且字符串是合法全名。

  getSupportedSourceVersion 指定Java版本

  process(Set《? extends TypeElement》 annotations, RoundEnvironment roundEnv) 这个也是最主要的,在这里扫描和处理你的注解并生成Java代码,信息都在参数RoundEnvironment 里了,后面会介绍。

  在Java7 中还可以使用

  @SupportedSourceVersion(SourceVersion.latestSupported())

  @SupportedAnnotationTypes({

  // 合法注解全名的集合

  })

  代替 getSupportedSourceVersion() 和 getSupportedAnnotationType() ,没毛病,还可以在注解处理离器中使用注解。

  注册注解处理器

  打包注解处理器的时候需要一个特殊的文件 javax.annotation.processing.Processor 在 META-INF/services 路径下

  --myprcessor.jar

  ----com

  ------example

  --------MyProcessor.class

  ----META-INF

  ------services

  --------javax.annotation.processing.Processor

  打包进javax.annotation.processing.Processor的内容是处理器的合法全称,多个处理器之间换行。

  com.example.myprocess.MyProcessorA

  com.example.myprocess.MyProcessorB

  google提供了一个注册处理器的库

  compile ‘com.google.auto.service:auto-service:1.0-rc2’

  一个注解搞定:

  @AutoService(Processor.class)

  public class MyProcessor extends AbstractProcessor {

  。。.

  }

  读到这里ButterKnife用到的知识点我们都已经了解了

  1.自定义注解

  2.用注解处理器解析注解

  3.解析完成后生成Java文件

  BufferKnife使用:

  public class MainActivity extends AppCompatActivity {

  @Bind(R.id.rxjava_demo)

  Button mRxJavaDemo;

  @Override

  protected void onCreate(Bundle savedInstanceState) {

  super.onCreate(savedInstanceState);

  setContentView(R.layout.activity_main);

  ButterKnife.bind(this);

  mRxJavaDemo.setText(“Text”);

  }

  }

  然后我们编译一下,打开路径:/app/build/intermediates/classes/release/com/ming/rxdemo/MainActivity$$ViewBinder.class

  这就是我们生成的Java文件,可以看到Button已经在bind里面初始化了。

  public class MainActivity$$ViewBinder《T extends MainActivity》 implements ViewBinder《T》 {

  public MainActivity$$ViewBinder() {

  }

  public void bind(Finder finder, T target, Object source) {

  View view = (View)finder.findRequiredView(source, 2131492944, “field \‘mRxJavaDemo\’”);

  target.mRxJavaDemo = (Button)finder.castView(view, 2131492944, “field \‘mRxJavaDemo\’”);

  }

  public void unbind(T target) {

  target.mRxJavaDemo = null;

  }

  }

  接下来我们创建一个项目,写一个简单的用注解绑定控件的例子

  项目结构

  --apt-demo

  ----bindview-annotation(Java Library)

  ----bindview-api(Android Library)

  ----bindview-compiler(Java Library)

  ----app(Android App)

  bindview-annotation 注解声明

  bindview-api 调用Android SDK API

  bindview-compiler 注解处理器相关

  app 测试App

  1.在 bindview-annotation 下创建一个@BindView注解,该注解返回一个值,整型,名字为value,用来表示控件ID。

  @Target(ElementType.FIELD)

  @Retention(RetentionPolicy.CLASS)

  public @interface BindView {

  /**

  * 用来装id

  *

  * @return

  */

  int value();

  }

  2.在 bindview-compiler 中创建注解处理器 BindViewProcessor 并注册,做基本的初始化工作。

  @AutoService(Processor.class)

  public class BindViewProcessor extends AbstractProcessor {

  /**

  * 文件相关的辅助类

  */

  private Filer mFiler;

  /**

  * 元素相关的辅助类

  */

  private Elements mElementUtils;

  /**

  * 日志相关的辅助类

  */

  private Messager mMessager;

  /**

  * 解析的目标注解集合

  */

  private Map《String, AnnotatedClass》 mAnnotatedClassMap = new HashMap《》();

  @Override

  public synchronized void init(ProcessingEnvironment processingEnv) {

  super.init(processingEnv);

  mElementUtils = processingEnv.getElementUtils();

  mMessager = processingEnv.getMessager();

  mFiler = processingEnv.getFiler();

  }

  @Override

  public Set《String》 getSupportedAnnotationTypes() {

  Set《String》 types = new LinkedHashSet《》();

  types.add(BindView.class.getCanonicalName());//返回该注解处理器支持的注解集合

  return types;

  }

  @Override

  public SourceVersion getSupportedSourceVersion() {

  return SourceVersion.latestSupported();

  }

  @Override

  public boolean process(Set《? extends TypeElement》 annotations, RoundEnvironment roundEnv) {

  return true;

  }

  }

  是不是注意到了里面有个Map容器,而且类型是AnnotatedClass,这是干啥的呢?这个很好理解,我们在解析XML,解析Json的时候数据解析完之后是不是要以对象的形式表示出来,这里也一样,@BindView用来标记类成员,一个类下可以有多个成员,好比一个Activity中可以有多个控件,一个容器下有多个控件等。如下:

  package com.mingwei.myprocess.model;

  import com.mingwei.myprocess.TypeUtil;

  import com.squareup.javapoet.ClassName;

  import com.squareup.javapoet.JavaFile;

  import com.squareup.javapoet.MethodSpec;

  import com.squareup.javapoet.ParameterizedTypeName;

  import com.squareup.javapoet.TypeName;

  import com.squareup.javapoet.TypeSpec;

  import java.util.ArrayList;

  import java.util.List;

  import javax.lang.model.element.Modifier;

  import javax.lang.model.element.TypeElement;

  import javax.lang.model.util.Elements;

  /**

  * Created by mingwei on 12/10/16.

  * CSDN: http://blog.csdn.net/u013045971

  * Github: https://github.com/gumingwei

  */

  public class AnnotatedClass {

  /**

  * 类名

  */

  public TypeElement mClassElement;

  /**

  * 成员变量集合

  */

  public List《BindViewField》 mFiled;

  /**

  * 元素辅助类

  */

  public Elements mElementUtils;

  public AnnotatedClass(TypeElement classElement, Elements elementUtils) {

  this.mClassElement = classElement;

  this.mElementUtils = elementUtils;

  this.mFiled = new ArrayList《》();

  }

  /**

  * 获取当前这个类的全名

  */

  public String getFullClassName() {

  return mClassElement.getQualifiedName().toString();

  }

  /**

  * 添加一个成员

  */

  public void addField(BindViewField field) {

  mFiled.add(field);

  }

  /**

  * 输出Java

  */

  public JavaFile generateFinder() {

  return null;

  }

  /**

  * 包名

  */

  public String getPackageName(TypeElement type) {

  return mElementUtils.getPackageOf(type).getQualifiedName().toString();

  }

  /**

  * 类名

  */

  private static String getClassName(TypeElement type, String packageName) {

  int packageLen = packageName.length() + 1;

  return type.getQualifiedName().toString().substring(packageLen).replace(‘。’, ‘$’);

  }

  }

  成员用BindViewField表示,没什么复杂的逻辑,在构造函数判断类型和初始化,简单的get函数

  package com.mingwei.myprocess.model;

  import com.mingwe.myanno.BindView;

  import javax.lang.model.element.Element;

  import javax.lang.model.element.ElementKind;

  import javax.lang.model.element.Name;

  import javax.lang.model.element.VariableElement;

  import javax.lang.model.type.TypeMirror;

  /**

  * Created by mingwei on 12/10/16.

  * CSDN: http://blog.csdn.net/u013045971

  * Github: https://github.com/gumingwei

  * 被BindView注解标记的字段的模型类

  */

  public class BindViewField {

  private VariableElement mFieldElement;

  private int mResId;

  public BindViewField(Element element) throws IllegalArgumentException {

  if (element.getKind() != ElementKind.FIELD) {//判断是否是类成员

  throw new IllegalArgumentException(String.format(“Only field can be annotated with @%s”,

  BindView.class.getSimpleName()));

  }

  mFieldElement = (VariableElement) element;

  //获取注解和值

  BindView bindView = mFieldElement.getAnnotation(BindView.class);

  mResId = bindView.value();

  if (mResId 《 0) {

  throw new IllegalArgumentException(String.format(“value() in %s for field % is not valid”,

  BindView.class.getSimpleName(), mFieldElement.getSimpleName()));

  }

  }

  public Name getFieldName() {

  return mFieldElement.getSimpleName();

  }

  public int getResId() {

  return mResId;

  }

  public TypeMirror getFieldType() {

  return mFieldElement.asType();

  }

  }

  这里看到了很多的Element,在Xml解析时候就有Element这个概念。在Java源文件中同样有Element概念:

  package com.example; // PackageElement

  public class MyClass { // TypeElement

  private int a; // VariableElement

  private Foo other; // VariableElement

  public Foo () {} // ExecuteableElement

  public void setA ( // ExecuteableElement

  int newA // TypeElement

  ) {

  }

  }

  接下来就是在处理器的process中解析注解了

  每次解析前都要清空,因为process方法可能不止走一次。

  拿到注解模型之后遍历调用生成Java代码

  @Override

  public boolean process(Set《? extends TypeElement》 annotations, RoundEnvironment roundEnv) {

  mAnnotatedClassMap.clear();

  try {

  processBindView(roundEnv);

  } catch (IllegalArgumentException e) {

  error(e.getMessage());

  return true;

  }

  try {

  for (AnnotatedClass annotatedClass : mAnnotatedClassMap.values()) {

  info(“generating file for %s”, annotatedClass.getFullClassName());

  annotatedClass.generateFinder().writeTo(mFiler);

  }

  } catch (Exception e) {

  e.printStackTrace();

  error(“Generate file failed,reason:%s”, e.getMessage());

  }

  return true;

  }

  processBindView 和 getAnnotatedClass

  /**

  * 遍历目标RoundEnviroment

  * @param roundEnv

  */

  private void processBindView(RoundEnvironment roundEnv) {

  for (Element element : roundEnv.getElementsAnnotatedWith(BindView.class)) {

  AnnotatedClass annotatedClass = getAnnotatedClass(element);

  BindViewField field = new BindViewField(element);

  annotatedClass.addField(field);

  }

  }

  /**

  * 如果在map中存在就直接用,不存在就new出来放在map里

  * @param element

  */

  private AnnotatedClass getAnnotatedClass(Element element) {

  TypeElement encloseElement = (TypeElement) element.getEnclosingElement();

  String fullClassName = encloseElement.getQualifiedName().toString();

  AnnotatedClass annotatedClass = mAnnotatedClassMap.get(fullClassName);

  if (annotatedClass == null) {

  annotatedClass = new AnnotatedClass(encloseElement, mElementUtils);

  mAnnotatedClassMap.put(fullClassName, annotatedClass);

  }

  return annotatedClass;

  }

  3.在生成Java之前 我们要在bindview-api 中创建一些类,配合 bindview-compiler 一起使用。

  你在使用Butterknife的时候不是要在onCreate里掉用一下BindView.bind(this)吗,那这个玩意是干什么呢。试想一下,前面做的一大堆工作是为了生成自动绑定控件的Java代码,如果生成的Java代码不能和你要使用的地方关联起来,那也是没有用的,可以把BindView.bind(this)理解为调用了你生成的Java代码,而生成了代码中完成了一些控件的初始化工作,自然你的控件就变得可用了。

  接口:Finder 定义findView方法

  实现类:ActivityFinder Activity中使用,ViewFinder View中使用

  接口:Injector inject方法将来是要创建在生成的Java文件中,用该方法中传递过来的参数进行控件的初始化。

  辅助类:ViewInjector 调用和传递参数

  这个代码我就不贴了,就一点点内容,一看就明白了。

  4.在AnnotatedClass中生成Java代码

  生成代码使用了一个很好用的库 Javapoet 。类,方法,都可以使用构建器构建出来,很好上手,再也不用拼接字符串了。哈哈哈哈~

  public JavaFile generateFinder() {

  //构建方法

  MethodSpec.Builder injectMethodBuilder = MethodSpec.methodBuilder(“inject”)

  .addModifiers(Modifier.PUBLIC)//添加描述

  .addAnnotation(Override.class)//添加注解

  .addParameter(TypeName.get(mClassElement.asType()), “host”, Modifier.FINAL)//添加参数

  .addParameter(TypeName.OBJECT, “source”)//添加参数

  .addParameter(TypeUtil.FINDER, “finder”);//添加参数

  for (BindViewField field : mFiled) {

  //添加一行

  injectMethodBuilder.addStatement(“host.$N=($T)finder.findView(source,$L)”, field.getFieldName()

  , ClassName.get(field.getFieldType()), field.getResId());

  }

  String packageName = getPackageName(mClassElement);

  String className = getClassName(mClassElement, packageName);

  ClassName bindClassName = ClassName.get(packageName, className);

  //构建类

  TypeSpec finderClass = TypeSpec.classBuilder(bindClassName.simpleName() + “$$Injector”)//类名

  .addModifiers(Modifier.PUBLIC)//添加描述

  .addSuperinterface(ParameterizedTypeName.get(TypeUtil.INJECTOR, TypeName.get(mClassElement.asType())))//添加接口(类/接口,范型)

  .addMethod(injectMethodBuilder.build())//添加方法

  .build();

  return JavaFile.builder(packageName, finderClass).build();

  }

  public String getPackageName(TypeElement type) {

  return mElementUtils.getPackageOf(type).getQualifiedName().toString();

  }

  private static String getClassName(TypeElement type, String packageName) {

  int packageLen = packageName.length() + 1;

  return type.getQualifiedName().toString().substring(packageLen).replace(‘。’, ‘$’);

  }

  可以在代码里System.out调试注解处理器的代码。

  还要注意的一点,项目之间的相互引用。

  bindview-complier 引用 bindview-annotation

  app 引用了剩下的三个module,在引用 bindview-complier 的时候用的apt的方式

  apt project(‘:bindview-compiler’)

  就写到这里吧,Demo 放在 Github上了

查看详情

processor技术

查看更多>>

processor资讯

Simple Circuit Activates Fan W

Simple Circuit Activates Fan W

Abstract: A circuit is shown that senses the temperature of a remote thermal...

2009-04-18 标签:Processor 1135 0

查看更多>>

processor数据手册

相关标签

相关话题

换一批
  • wifi模块
    wifi模块
    +关注
    Wi-Fi模块又名串口Wi-Fi模块,属于物联网传输层,功能是将串口或TTL电平转为符合Wi-Fi无线网络通信标准的嵌入式模块,内置无线网络协议IEEE802.11b.g.n协议栈以及TCP/IP协议栈。传统的硬件设备嵌入Wi-Fi模块可以直接利用Wi-Fi联入互联网,是实现无线智能家居、M2M等物联网应用的重要组成部分。
  • UHD
    UHD
    +关注
    UHD是”超高清“的意思UHD的应用在电视机技术上最为普遍,目前已有不少厂商推出了UHD超高清电视。
  • 四轴飞行器
    四轴飞行器
    +关注
    四轴飞行器,又称四旋翼飞行器、四旋翼直升机,简称四轴、四旋翼。这四轴飞行器(Quadrotor)是一种多旋翼飞行器。四轴飞行器的四个螺旋桨都是电机直连的简单机构,十字形的布局允许飞行器通过改变电机转速获得旋转机身的力,从而调整自身姿态。具体的技术细节在“基本运动原理”中讲述。
  • STEP7
    STEP7
    +关注
    STEP 7是一款编程软件,厂商是西门子,用于西门子系列工控产品包括SIMATIC S7、M7、C7和基于PC的WinAC的编程、监控和参数设置,是SIMATIC工业软件的重要组成部分。
  • 车载摄像头
    车载摄像头
    +关注
    车载摄像头能非常实时的呈现视频和音频的功能为我们交通事故个处理和定位提供了更科学的依据,让我们的财产和人生安全得到了充分的保障。
  • LPC1114
    LPC1114
    +关注
    LPC1114是NXP公司推出的一款ARM Cortex-M0 内核的32位单片机。它的主频最大可达50MHz,内部集成时钟产生单元,不用外部晶振也可以工作。
  • 射频器件
    射频器件
    +关注
  • 开发套件
    开发套件
    +关注
    开发套件是集成了仿真、输入输出、usb、lcd、网络等许多接口的单片机开发工具。通过usb接口连接电脑,具有代码高速下载,在线调试,断点、单步、变量观察,寄存器观察等功能,实现对单片机实时在线仿真、调试。开发套件能够协助初学者和设计人员快速评估及进行多种应用开发,熟悉掌握硬件原理和协议栈。
  • 液晶彩电
    液晶彩电
    +关注
  • LM3S8962
    LM3S8962
    +关注
  • ACS800
    ACS800
    +关注
  • 文本显示器
    文本显示器
    +关注
      文本显示器,又名终端显示器,是一种单纯以文字呈现的人机互动系统。通过文本显示器,将所需要控制的内容,编写成相应的程序,最终在文本显示器的界面上显示出来。这样,不但大大提高了操作的方便性,而且能够显著提高工作效率。
  • 光电探测器
    光电探测器
    +关注
    光电探测器的原理是由辐射引起被照射材料电导率发生改变。光电探测器在军事和国民经济的各个领域有广泛用途。在可见光或近红外波段主要用于射线测量和探测、工业自动控制、光度计量等;在红外波段主要用于导弹制导、红外热成像、红外遥感等方面。
  • TPU
    TPU
    +关注
    热塑性聚氨酯弹性体又称热塑性聚氨酯橡胶,简称TPU,是一种(AB)n型嵌段线性聚合物,A为高分子量(1000~6000)的聚酯或聚醚,B为含2~12直链碳原子的二醇,AB链段间化学结构是二异氰酸酯。热塑性聚氨酯橡胶靠分子间氢键交联或大分子链间轻度交联,随着温度的升高或降低,这两种交联结构具有可逆性。
  • 马达驱动
    马达驱动
    +关注
    Motor drive组装在照相内的弹簧或附件,借助微型电机自动地卷取胶片,大多是指35毫米单镜头反光相机所用的。拍一片格和连拍可以交替,连拍时一般一秒钟拍3—5片格。视照相机的种类,将背部盖子换为长胶卷用片盒,即可拍250片格。
  • OK6410
    OK6410
    +关注
  • AWR
    AWR
    +关注
  • 74LS151
    74LS151
    +关注
  • FHD
    FHD
    +关注
  • 安防芯片
    安防芯片
    +关注
  • 电容笔
    电容笔
    +关注
  • 飞凌
    飞凌
    +关注
  • Hi3516
    Hi3516
    +关注
  • CC2640
    CC2640
    +关注
  • HD-SDI
    HD-SDI
    +关注
  • SOP封装
    SOP封装
    +关注
  • 工业路由器
    工业路由器
    +关注
    工业路由器是一种,利用公用无线网络为用户提供无线的数据传输功能。已广泛应用于物联网产业链中的M2M行业,如智能电网、智能交通、智能家居、金融物联网无线通信路由器、移动POS终端、供应链自动化、工业自动化、智能建筑、消防、公共安全、环境保护、气象、数字化医疗、遥感勘测、农业、林业、水务、煤矿、石化等领域。
  • McAfee
    McAfee
    +关注
  • 高清技术
    高清技术
    +关注
  • S3F9454
    S3F9454
    +关注

关注此标签的用户(0人)

编辑推荐厂商产品技术软件/工具OS/语言教程专题