制作library时省去application的初始化

原文地址 http://blog.csdn.net/qq_25806863/article/details/62232911

来自 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()之前执行,。。。不知道理解有没有错:
这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值