标签:xml Context LitePal Application context AndroidManifest public
在阅读《第一行代码》的LitePal这一节时,注意到要能够正常使用LitePal,我们必须在AndroidManifest.xml中配置如下内容:
<application
android:name="org.litepal.LitePalApplication"
...>
...
</application>
其原因是经过这样的配置以后,当程序启动的的时候就会初始化 LitePalApplication
类,而不是默认的 Application
类,而经过这样的初始化之后,我们就已经实现了一种全局获取 Context
的机制,之后 LitePal 就能在内部自动获取到 Context 了。
到这里我的问题已经解决了,但是在阅读过程中,注意到作者提出了一个问题,即,如果我们已经配置过了自己的 Application 怎么办?这样岂不是和 LitePalApplication 冲突了?没错,任何一个项目都只能配置一个 Application,对于这种情况,LitePal 提供了很简单的解决方案,那就是在我们自己的 Application 中去调用 LitePal 的初始化方法就可以了,如下:
public class MyApplication extends Application {
private static Context context;
@Override
public void onCreate() {
context = getApplicationContext();
LitePal.initialize(context);
}
public static Context getContext() {
return context;
}
}
使用这种写法,就相当于我们把全局的Context对象通过参数传递给了LitePal,效果和在AndroidManifest.xml中配置LitePalApplication是一模一样的。
标签:xml,Context,LitePal,Application,context,AndroidManifest,public 来源: https://www.cnblogs.com/fanlumaster/p/13728771.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。