共计 3725 个字符,预计需要花费 10 分钟才能阅读完成。
本教程次要具体解说 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
正文完