博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【七】注入框架RoboGuice使用:(Your First Custom Binding)
阅读量:5024 次
发布时间:2019-06-12

本文共 1409 字,大约阅读时间需要 4 分钟。

           上一篇我们简单的介绍了一下RoboGuice的使用(),今天我们来看下自己定义绑定(binding)。

           (一):使用自己定义绑定。我们能够绑定一个类或者一个接口到一个子类。实例或者内容提供者(provinders).

         如今我们如果:

public interface IFoo {}public class Foo implements IFoo {}
         该自己定义绑定同意绑定一个接口IFoo到类Foo中,然后每个注解(@Inject IFoo),就会创建一个Foo的实例。

public class MyActivity extends RoboActivity {    //How to tell RoboGuice to inject an instance of Foo ?

@Inject IFoo foo; }

      (二):定义自己定义绑定:

      进行自己定义绑定。我们须要创建自己的module(s)。从RoboGuice 2.0版本号開始Modules变得非常easy创建。   

           ①:在Androidmanifset.xml中注冊Modules

           ②:创建继承AbstractModule的类

      2.1:在Androidmanifset.xml中注冊Modules

             在Androidmanifset.xml中,application标签中加入一些meta-data标签字段以及modules全名,例如以下所看到的:

  
   2.2:
创建继承AbstractModule的类

          每个modules必须在创建之前必需要注冊,这些所有会通过反射进行訪问。看以下的实例代码:

package com.example;public class MyModule extends AbstractModule {     //a default constructor is fine for a Module    public void bind() {        bind(IFoo.class).to(Foo.class);    }}public class MyModule2 extends AbstractModule {    //if your module requires a context, add a constructor that will be passed a context.    private Context context;    //with RoboGuice 3.0, the constructor for AbstractModule will use an `Application`, not a `Context`    public MyModule( Context context ) {        this.context = context;    }    public void bind() {        bind(IFoo.class).toInstance( new Foo(context));    }}

           

           

版权声明:本文博客原创文章。博客,未经同意,不得转载。

转载于:https://www.cnblogs.com/bhlsheji/p/4638630.html

你可能感兴趣的文章
盒子模型
查看>>
局域网协议
查看>>
[HNOI2012]永无乡 线段树合并
查看>>
Spring整合hibernate:3、使用XML进行声明式的事务管理
查看>>
SqlServer之Convert 函数应用格式化日期(转)
查看>>
软件测试领域中的10个生存和发展技巧
查看>>
Camera前后摄像头同时预览
查看>>
HDU 1856
查看>>
课堂作业01--架构师的职责
查看>>
iOS计算富文本(NSMutableAttributedString)高度
查看>>
2017/09/15 ( 框架2)
查看>>
Centos下源码安装git
查看>>
gulp-rev-append md5版本号
查看>>
IO流之File类
查看>>
sql 基础语句
查看>>
CF717A Festival Organization(第一类斯特林数,斐波那契数列)
查看>>
oracle直接读写ms sqlserver数据库(二)配置透明网关
查看>>
控件发布:div2dropdownlist(div模拟dropdownlist控件)
查看>>
Oracle composite index column ordering
查看>>
ActiveReports 报表控件官方中文入门教程 (3)-如何选择页面报表和区域报表
查看>>