关于java:Guice依赖注入一

本教程次要具体解说Guice的一些根本注入形式,通过该简略教程让咱们能够疾速应用Guice进行简略系统化开发,后续咱们会更深刻解说更多模块,如果还不理解Guice大家能够先去网上自行理解一下.

根底环境


技术 版本
Java 1.8+
Guice 4.2.3

初始化我的项目


  • 初始化我的项目
mvn archetype:generate -DgroupId=com.edurt.sli.guice -DartifactId=guice-basic -DarchetypeArtifactId=maven-archetype-quickstart -Dversion=1.0.0 -DinteractiveMode=false
  • 批改pom.xml减少Guice依赖
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
 <parent> <artifactId>learn-integration-guice</artifactId> <groupId>com.edurt.sli.guice</groupId> <version>1.0.0</version> </parent>
 <modelVersion>4.0.0</modelVersion>
 <artifactId>guice-basic</artifactId>
 <name>Guice基础教程</name>
 <properties> <system.java.version>1.8</system.java.version> <guice.version>4.2.3</guice.version> </properties>
 <dependencies> <dependency> <groupId>com.google.inject</groupId> <artifactId>guice</artifactId> <version>${guice.version}</version> </dependency> </dependencies>
 <build> <plugins> <plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-compiler-plugin</artifactId> <version>${plugin.maven.compiler.version}</version> <configuration> <source>${system.java.version}</source> <target>${system.java.version}</target> </configuration> </plugin> </plugins> </build>
</project>

guice: guice就是咱们外围要应用的依赖

Guice的绑定模型

  • src/main/java目录下新建com.edurt.sli.guice.sample目录并在该目录下新建GuiceBasicModule类文件,在文件输出以下内容
package com.edurt.sli.guice.sample;
import com.google.inject.AbstractModule;
public class GuiceBasicModule extends AbstractModule {
 @Override protected void configure() { }
}

Guice中的绑定模型和Spring中的一样简略,咱们通过绑定能够提供给程序任意注入类.
绑定咱们须要的Module只须要继承Guice中的com.google.inject.AbstractModule即可,在configure办法中实现咱们须要的绑定信息.

  • com.edurt.sli.guice.sample目录下构建GuiceBasicService接口类,内容如下
package com.edurt.sli.guice.sample;
public interface GuiceBasicService {
 void print(String output);
}
  • com.edurt.sli.guice.sample目录下构建GuiceBasicServiceImpl接口实现类,内容如下
package com.edurt.sli.guice.sample;
public class GuiceBasicServiceImpl implements GuiceBasicService {
 public void print(String output) { System.out.println(String.format("print %s", output)); }
}
  • 接下来批改GuiceBasicModule将咱们定义的服务进行绑定,代码如下
package com.edurt.sli.guice.sample;
import com.google.inject.AbstractModule;
public class GuiceBasicModule extends AbstractModule {
 @Override protected void configure() { bind(GuiceBasicService.class).to(GuiceBasicServiceImpl.class); }
}

这样咱们就很快的绑定了一个服务,相似于Spring中的@Bean形式
bind标记咱们须要绑定的类,to标记咱们绑定的实现类

  • com.edurt.sli.guice.sample目录下构建GuiceBasicApplication类文件用于咱们测试代码,在文件输出以下内容
package com.edurt.sli.guice.sample;
import com.google.inject.Guice;
import com.google.inject.Injector;
public class GuiceBasicApplication {
 public static void main(String[] args) { Injector injector = Guice.createInjector(new GuiceBasicModule()); GuiceBasicService service = injector.getInstance(GuiceBasicService.class);
 service.print("Hello Guice"); }
}

咱们运行程序,控制台会输入如下内容:

print Hello Guice

构造函数绑定


  • 首先咱们构建用于注入的服务类,代码如下
@ImplementedBy(ConstructorServiceImpl.class)
interface ConstructorService {
 void print();
}

@ImplementedBy告知咱们程序咱们的接口具体实现类,Guice会帮咱们做主动实例化

  • 服务实现类,咱们打印简略的字符串,代码如下
class ConstructorServiceImpl implements ConstructorService {
 @Override public void print() { System.out.println("Hello Guice By Constructor"); }
}
  • 应用构造函数进行注入,代码如下
public class ConstructorApplication {
 private ConstructorService service;
 @Inject public ConstructorApplication(ConstructorService service) { this.service = service; }
 public ConstructorService getService() { return service; }
 public static void main(String[] args) { ConstructorApplication instance = Guice.createInjector().getInstance(ConstructorApplication.class); instance.getService().print(); }
}

咱们运行程序,控制台会输入如下内容:

Hello Guice By Constructor

打包文件部署


  • 打包数据
mvn clean package -Dmaven.test.skip=true -X

运行打包后的文件即可

java -jar target/guice-binder-1.0.0.jar

源码地址


  • GitHub

评论

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

这个站点使用 Akismet 来减少垃圾评论。了解你的评论数据如何被处理