您的位置:首页 > 移动开发

Application的用法以及安卓入口问题的理解

2015-01-08 13:43 309 查看
Application 配置全局Context

第一步、写一个全局的单例模式的MyApplication继承自Application 覆盖onCreate ,在这个方法里面实例化Application

第二步、配置全局的Context

<application android:name="com.appstore.service.MyApplication" ></application>

第三步、使用的时候用根据类的名称访问Context


Android程序的入口点



可能很多人不知道Android程序的入口点是什么,不是main()吗?很多网友可能直接回复是onCreate,当然我相信回复onCreate的在字面上不算错,但是你们想的是Activity中的onCreate方法吧。

Android使用Google Dalvik VM,相对于传统Java VM而言有着很大的不同,在Sun的Java体系中入口点和标准c语言一样是main(),而每个Android程序都包含着一个Application实例,一个Application实例中有多个Activity、Service、ContentProvider或Broadcast Receiver。因为大部分的应用都包含Activity,所以说很多网友认为是Activity的onCreate,但是你没有发现你的工程中有多个Activity吗? 你可能没有见过没有Activity的Android应用吧。

其实在android.app.Application这个包的onCreate才是真正的Android入口点,只不过大多数开发者无需重写该类,他的继承关系如下图:

java.lang.Object

->android.content.Context

->android.content.ContextWrapper

-> android.app.Application

android.app.Application类包含了4个公开的方法

void onConfigurationChanged(Configuration newConfig)

void onCreate() //这里才是真正的入口点。

void onLowMemory()

void onTerminate()

Android入口点是application的main,看下androidmanifest.xml的包含关系就清楚了,并不是每个应用都必须有Activity的。

android中application 关于全局变量



android编程中,application这样的名词似乎变得那样的不常见,而让大家更为熟悉的是activity、intent、provider、broadcast和service,但其实android中的application也有着它自身的用处。

打开manifest文件,会看到有一个application配置标签,这就是有关application的使用了。那究竟application有什么用处呢?来看看SDK中是如何描述的:

Base class for those who need to maintain global application state. You can provide your own implementation by specifying its name in your AndroidManifest.xml's < application> tag, which will cause that class to be instantiated for you when the process for
your application/package is created.

  就是说application是用来保存全局变量的,并且是在package创建的时候就跟着存在了。所以当我们需要创建全局变量的时候,不需要再像 j2se那样需要创建public权限的static变量,而直接在application中去实现。只需要调用Context的 getApplicationContext或者Activity的getApplication方法来获得一个application对象,再做出相应的处理。

针对国际化的app可在[b]application中进行语言本地化的工作.[/b]

[java] view
plaincopy

// Are we using advanced debugging - locale?

SharedPreferences pref = PreferenceManager

.getDefaultSharedPreferences(this);

String p = pref.getString("set_locale", "");

if (p != null && !p.equals("")) {

Locale locale;

// workaround due to region code

if (p.equals("zh-TW")) {

locale = Locale.TRADITIONAL_CHINESE;

} else if (p.startsWith("zh")) {

locale = Locale.CHINA;

} else if (p.equals("pt-BR")) {

locale = new Locale("pt", "BR");

} else if (p.equals("bn-IN") || p.startsWith("bn")) {

locale = new Locale("bn", "IN");

} else {

/**

* Avoid a crash of java.lang.AssertionError: couldn't

* initialize LocaleData for locale if the user enters

* nonsensical region codes.

*/

if (p.contains("-"))

p = p.substring(0, p.indexOf('-'));

locale = new Locale(p);

}

Locale.setDefault(locale);

Configuration config = new Configuration();

config.locale = locale;<pre name="code" class="java"> getBaseContext().getResources().updateConfiguration(config,

getBaseContext().getResources().getDisplayMetrics());


                                            
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: