来自 Android Debug Database
http://blog.csdn.net/qq_25806863/article/details/62216763

问题

在使用Android Debug Database的时候,我发现仅仅是加一行引用就行了

1
debugCompile 'com.amitshekhar.android:debug-db:1.0.0'

代码中没有写一点点关于这个库的代码。自定义控件那种就不说了,用到的时候肯定会调用的。而一些工具库最起码也要在Application的onCreate()方法中写一行代码什么的,需要配置一些id的这样还可以,l例如微信这些。还有些就仅仅是依据初始化:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
public class DemoApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
LeakCanary.install(this);//像这样的。
APICloud.initialize(this);
//微信 appid appsecret
PlatformConfig.setWeixin("wxbe344a7447dcf578f", "df0e35026180c930e30335436e149c7b6");
api = WXAPIFactory.createWXAPI(getApplicationContext(), "wxbe4d346a747d4f4578f");
api.registerApp("wxb34a747dc43f578f");
}
}

发现

我就好奇Android Debug Database是怎么做的了。
看源码的时候发现,Android Debug Database里面写了一个内容提供者DebugDBInitProvider。代码很简单,觉得在写library的时候有时可以用下。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
public class DebugDBInitProvider extends ContentProvider {
public DebugDBInitProvider() {
}
@Override
public boolean onCreate() {
Log.i(TAG, "onCreate: DebugDBInitProvider");
DebugDB.initialize(getContext());
return true;
}
@Override
public Cursor query(Uri uri, String[] projection, String selection, String[] selectionArgs, String sortOrder) {
return null;
}
@Override
public String getType(Uri uri) {
return null;
}
@Override
public Uri insert(Uri uri, ContentValues values) {
return null;
}
@Override
public int delete(Uri uri, String selection, String[] selectionArgs) {
return 0;
}
@Override
public int update(Uri uri, ContentValues values, String selection, String[] selectionArgs) {
return 0;
}
@Override
public void attachInfo(Context context, ProviderInfo providerInfo) {
if (providerInfo == null) {
throw new NullPointerException("DebugDBInitProvider ProviderInfo cannot be null.");
}
// So if the authorities equal the library internal ones, the developer forgot to set his applicationId
if ("com.amitshekhar.DebugDBInitProvider".equals(providerInfo.authority)) {
throw new IllegalStateException("Incorrect provider authority in manifest. Most likely due to a "
+ "missing applicationId variable in application\'s build.gradle.");
}
super.attachInfo(context, providerInfo);
}
}

这个provider几乎就是个空的,只是在onCreate()方法中执行了一下DebugDB.initialize(getContext());
而这个方法就是这个类库的入口。为什么要写成这样的呢?

把这行代码注释掉,然后在自己的Application中写上,能达到一样的效果:

1
2
3
4
5
6
7
8
public class App extends Application {
@Override
public void onCreate() {
super.onCreate();
DebugDB.initialize(getApplicationContext());
Log.i(TAG, "onCreate: Application");
}
}

结果

个人认为这个provider的作用就是方便其他人使用这个类库。不需要集成Application,不需要写那行列代码。

原因就是provider的onCreate()会在application的onCreate()之前执行,。。。不知道理解有没有错:
这里写图片描述