// .test1Module(new Test1Module(this))
.build()
.inject(this);
}
@OnClick(R.id.btn1)
public void onViewClicked() {
Toast.makeText(this, student.toString(), Toast.LENGTH_SHORT).show();
}
}
2、源码解析
======
打开目录结构:
我们不难发现,编译器已经帮我们生成了这样几个文件:
-
Student_Factory
-
DaggerTest1Component
-
Test1Activity_MembersInjector
-
Test1Activity_ViewBinding(不用管,butterknife)
我们一一进行分析:
2.1、Student_Factory
上一篇文章我们已经进行了分析,很简单,当我们@Inject注解一个类的构造方法时,编译器会自动帮我们生成一个工厂类,负责生产该类的对象,类似于商品的厂家:
package com.gs.dagtest1.bean;
import dagger.internal.Factory;
public final class Student_Factory implements Factory {
private static final Student_Factory INSTANCE = new Student_Factory();
@Override
public Student get() {
return provideInstance();
}
public static Student provideInstance() {
return new Student();
}
public static Student_Factory create() {
return INSTANCE;
}
public static Student newStudent() {
return new Student();
}
}
2.2、DaggerTest1Component
public final class DaggerTest1Component implements Test1Component {
private DaggerTest1Component(Builder builder) {}
public static Builder builder() {
return new Builder();
}
public static Test1Component create() {
return new Builder().build();
}
@Override
public void inject(Test1Activity activity) {
injectTest1Activity(activity);
}
private Test1Activity injectTest1Activity(Test1Activity instance) {
Test1Activity_MembersInjector.injectStudent(instance, new Student());
return instance;
}
public static final class Builder {
private Builder() {}
public Test1Component build() {
return new DaggerTest1Component(this);
}
/**
-
@deprecated This module is declared, but an instance is not used in the component. This
-
method is a no-op. For more, see https://google.github.io/dagger/unused-modules.
*/
@Deprecated
public Builder test1Module(Test1Module test1Module) {
Preconditions.checkNotNull(test1Module);
return this;
}
}
}
2.3、Test1Activity_MembersInjector
public final class Test1Activity_MembersInjector implements MembersInjector {
private final Provider studentProvider;
public Test1Activity_MembersInjector(Provider studentProvider) {
this.studentProvider = studentProvider;
}
public static MembersInjector create(Provider studentProvider) {
return new Test1Activity_MembersInjector(studentProvider);
}
@Override
public void injectMembers(Test1Activity instance) {
injectStudent(instance, studentProvider.get());
}
public static void injectStudent(Test1Activity instance, Student student) {
instance.student = student;
}
}
很熟悉,我们在Activity中就用到了这个生成的类,编译器起名方式也很简洁:Dagger+你的Component接口名。
在我们的Activity中我们是这样使用:
DaggerTest1Component.builder()
// .test1Module(new Test1Module(this))
.build()
.inject(this);
我们根据这个步骤查看源码,发现
DaggerTest1Component.builder().build()
实际上是通过建造者模式创建了一个新的DaggerTest1Component对象而已。
然后通过调用
DaggerTest1Component.java
DaggerTest1Component.builder().build().inject(this);
@Override
public void inject(Test1Activity activity) {
injectTest1Activity(activity);
}
private Test1Activity injectTest1Activity(Test1Activity instance) {
Test1Activity_MembersInjector.injectStudent(instance, new Student());
return instance;
}
Test1Activity_MembersInjector.java
public static void injectStudent(Test1Activity instance, Student student) {
instance.student = student;
}
可以看到这些代码最终是把activity对象和student对象都 传入到了Test1Activity_MembersInjector的injectStudent()方法中。
总结:绘上一张Kakfa架构思维大纲脑图(xmind)
其实关于Kafka,能问的问题实在是太多了,扒了几天,最终筛选出44问:基础篇17问、进阶篇15问、高级篇12问,个个直戳痛点,不知道如果你不着急看答案,又能答出几个呢?
若是对Kafka的知识还回忆不起来,不妨先看我手绘的知识总结脑图(xmind不能上传,文章里用的是图片版)进行整体架构的梳理
梳理了知识,刷完了面试,如若你还想进一步的深入学习解读kafka以及源码,那么接下来的这份《手写“kafka”》将会是个不错的选择。
-
Kafka入门
-
为什么选择Kafka
-
Kafka的安装、管理和配置
-
Kafka的集群
-
第一个Kafka程序
-
Kafka的生产者
-
Kafka的消费者
-
深入理解Kafka
-
可靠的数据传递
-
Spring和Kafka的整合
-
SpringBoot和Kafka的整合
-
Kafka实战之削峰填谷
-
数据管道和流式处理(了解即可)
你还想进一步的深入学习解读kafka以及源码,那么接下来的这份《手写“kafka”》将会是个不错的选择。
-
Kafka入门
-
为什么选择Kafka
-
Kafka的安装、管理和配置
-
Kafka的集群
-
第一个Kafka程序
-
Kafka的生产者
-
Kafka的消费者
-
深入理解Kafka
-
可靠的数据传递
-
Spring和Kafka的整合
-
SpringBoot和Kafka的整合
-
Kafka实战之削峰填谷
-
数据管道和流式处理(了解即可)
[外链图片转存中…(img-cnDNPkKI-1714284061266)]
[外链图片转存中…(img-EoYBbQtX-1714284061267)]