来自 Android Debug Database
http://blog.csdn.net/qq_25806863/article/details/62216763
问题
在使用Android Debug Database的时候,我发现仅仅是加一行引用就行了
debugCompile 'com.amitshekhar.android:debug-db:1.0.0'
代码中没有写一点点关于这个库的代码。自定义控件那种就不说了,用到的时候肯定会调用的。而一些工具库最起码也要在Application的onCreate()方法中写一行代码什么的,需要配置一些id的这样还可以,l例如微信这些。还有些就仅仅是依据初始化:
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的时候有时可以用下。
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中写上,能达到一样的效果:
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()之前执行,。。。不知道理解有没有错: