android uri 初始化,Android制作library时省去application的初始化

问题

在使用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()之前执行,。。。不知道理解有没有错:

1f9e609f7368?utm_campaign=maleskine&utm_content=note&utm_medium=seo_notes&utm_source=recommendation

这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值