成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

全面解析 Application 的使用

移動開發 Android
Application類在每一次開發當中是我們都會遇到的,每一個APP都會有一個Application實例,它擁有和APP一樣長的生命周期,Application和APP一起“同生共死”;

[[435976]]

前言

Application類在每一次開發當中是我們都會遇到的,每一個APP都會有一個Application實例,它擁有和APP一樣長的生命周期,Application和APP一起“同生共死”;

我們今天就來講解下,加強下基礎和內功,讓自己更有自信;

一、Application是什么?

  • android系統會為每一個程序運行時創建一個Application類的對象且僅創建一個,所以Application能夠說是單例 (singleton)模式的一個類;
  • application對象的生命周期是整個程序中最長的,它的生命周期就等于這個程序的生命周期。由于它是全局的單例的。所以在不同的Activity,Service中獲得的對象都是同一個對象;
  • Application和Activity,Service一樣是Android框架的一個系統組件,當Android程序啟動時系統會創建一個 Application對象,用來存儲系統的一些信息;
  • 通常我們是不需要指定一個Application的,系統會自動幫我們創建,如果需要創建自己的Application,那也很簡單,創建一個類繼承Application并在AndroidManifest.xml文件中的application標簽中進行注冊;
  • 啟動Application時,系統會創建一個PID,即進程ID,所有的Activity都會在此進程上運行;
  • Application對象的生命周期是整個程序中最長的,它的生命周期就等于這個程序的生命周期,因為它是全局的單例的,所以在不同的Activity,Service中獲得的對象都是同一個對象,所以可以通過Application來進行一些,如:數據傳遞、數據共享和數據緩存等操作;

二、Application類的方法

1、onCreate()方法

繼承自 ContextWarpper 類

  1. public class Application extends ContextWrapper implements ComponentCallbacks2 { 
  2. ... 
  3. ... 
  4.  public void onCreate() { 
  5.  } 
  • 在Application創建的時候調用,一般用于初始化一些東西,如全局的對象,環境的配置;
  • 設置全局共享數據,如全局共享變量、方法等;

注意:

共享數據只在應用程序的生命周期內有效,當該應用程序被殺死,這些數據也會被清空,所以只能存儲一些具備 臨時性的共享數據

請不要執行耗時操作,否則會拖慢應用程序啟動速度;

2、onConfigurationChanged(Configuration newConfig)

重寫此方法可以監聽APP一些配置信息的改變事件(如屏幕旋轉等);

當配置信息改變的時候會調用這個方法;

  1. registerComponentCallbacks(new ComponentCallbacks2() { 
  2.             @Override 
  3.             public void onConfigurationChanged(Configuration newConfig) { 
  4.               ... 
  5.             } 
  6.         }); 

3、onLowMemory()方法

  • 重寫此方法可以監聽Android系統整體內存較低時候的事件;
  • 調用時刻:Android系統整體內存較低時;
  1. registerComponentCallbacks(new ComponentCallbacks2() { 
  2.   @Override 
  3.             public void onLowMemory() { 
  4.             } 
  5.         }); 

4、onTerminate()方法

  • 通知 應用程序 當前內存使用情況(以內存級別進行識別)
  • 根據當前內存使用情況進行自身的內存資源的不同程度釋放,以避免被系統直接殺掉 & 優化應用程序的性能體驗;
  • 系統在內存不足時會按照LRU Cache中從低到高殺死進程;優先殺死占用內存較高的應用;
  1. registerComponentCallbacks(new ComponentCallbacks2() { 
  2. @Override 
  3.   public void onTrimMemory(int level) { 
  4.   // Android系統會根據當前內存使用的情況,傳入對應的級別 
  5.   // 下面以清除緩存為例子介紹 
  6.     super.onTrimMemory(level); 
  7.   .   if (level >= ComponentCallbacks2.TRIM_MEMORY_MODERATE) { 
  8.         mPendingRequests.clear(); 
  9.         mBitmapHolderCache.evictAll(); 
  10.         mBitmapCache.evictAll(); 
  11.     } 
  12.         }); 

5、registerActivityLifecycleCallbacks()和unregisterActivityLifecycleCallbacks()

這兩個方法用于注冊或者注銷對APP內所有Activity的生命周期監聽;

當APP內Activity的生命周期發生變化的時候就會調用ActivityLifecycleCallbacks里面的方法:

  1. registerActivityLifecycleCallbacks(new ActivityLifecycleCallbacks() { 
  2.             @Override 
  3.             public void onActivityCreated(Activity activity, Bundle savedInstanceState) { 
  4.                 Log.e(TAG,"onActivityCreated: " + activity.getLocalClassName()); 
  5.             } 
  6.             @Override 
  7.             public void onActivityStarted(Activity activity) { 
  8.                 Log.e(TAG,"onActivityStarted: " + activity.getLocalClassName()); 
  9.             } 
  10.             @Override 
  11.             public void onActivityResumed(Activity activity) { 
  12.                 Log.e(TAG,"onActivityResumed: " + activity.getLocalClassName()); 
  13.             } 
  14.             @Override 
  15.             public void onActivityPaused(Activity activity) { 
  16.                 Log.e(TAG,"onActivityPaused: " + activity.getLocalClassName()); 
  17.             } 
  18.             @Override 
  19.             public void onActivityStopped(Activity activity) { 
  20.                 Log.e(TAG, "onActivityStopped: " + activity.getLocalClassName()); 
  21.             } 
  22.             @Override 
  23.             public void onActivitySaveInstanceState(Activity activity, Bundle outState) { 
  24.             } 
  25.             @Override 
  26.             public void onActivityDestroyed(Activity activity) { 
  27.                 Log.e(TAG,"onActivityDestroyed: " + activity.getLocalClassName()); 
  28.             } 
  29.         }); 

查看log打印的情況如下:

  1. onActivityPaused: MainActivity 
  2.  
  3. onActivityStopped: MainActivity 
  4.  
  5. onActivityStarted: MainActivity 
  6.  
  7. onActivityResumed: MainActivity 

6、registerComponentCallbacks()和unregisterComponentCallbacks()方法

注冊和注銷 ComponentCallbacks2回調接口

  1. registerComponentCallbacks(new ComponentCallbacks2() { 
  2.             @Override 
  3.             public void onTrimMemory(int level) { 
  4.             } 
  5.             @Override 
  6.             public void onConfigurationChanged(Configuration newConfig) { 
  7.             } 
  8.             @Override 
  9.             public void onLowMemory() { 
  10.             } 
  11.         }); 

三、應用場景和自定義

1、應用場景

  1. 初始化應用程序級別的資源,如全局對象;
  2. 數據共享、數據緩存;
  3. 獲取應用程序當前的內存使用情況,及時釋放資源,從而避免被系統殺死;
  4. 監聽應用程序配置信息的改變,如屏幕旋轉等;
  5. 監聽應用程序內,所有Activity的生命周期;

2、自定義Application

(1)繼承Application

  1. public class MyApplication extends Application{ 
  2.    /**聲明變量*/ 
  3.     private String value; 
  4.     @Override 
  5.     public void onCreate() { 
  6.         super.onCreate(); 
  7.         // 初始化全局變量 
  8.         setValue(VALUE);  
  9.     } 
  10.     public void setValue(String value){ 
  11.         this.value = value; 
  12.     } 
  13.     public String getValue(){ 
  14.         return value; 
  15.     } 

注意:繼承Application類,主要重寫里面的onCreate()方法(android.app.Application包的onCreate()才是真正的Android程序的入口點),就是創建的時候,初始化變量的值。然后在整個應用中的各個文件中就可以對該變量進行操作了;

(2)在ApplicationManifest.xml文件中配置自定義的Application

  1. <application 
  2.        android:name="MyApplication"
  3. </application> 

(3)使用自定義的Application類實例

  1. private MyApplication app; 
  2. // 只需要調用Activity.getApplication() 或Context.getApplicationContext()就可以獲得一個Application對象 
  3. app = (MyApplication) getApplication(); 
  4. // 然后再得到相應的成員變量 或方法 即可 
  5. app.getValue(); 

總結

每個Android App運行時,會首先自動創建Application 類并實例化 Application 對象,且只有一個即 Application類 是單例模式(singleton)類;

即不同的組件(如Activity、Service)都可獲得Application對象且都是同一個對象; 

Application 對象的生命周期是整個程序中最長的,即等于Android App的生命周期。

 

責任編輯:武曉燕 來源: Android開發編程
相關推薦

2021-11-23 09:09:27

Applicationandroid系統開發

2017-05-23 15:47:04

JavaScriptthis解析

2017-04-10 18:34:16

AndroidNotificatio

2010-07-22 09:25:09

telnet命令

2010-06-24 15:35:04

IPx協議

2010-03-09 17:19:01

Linux時鐘

2024-08-29 08:28:17

2009-12-24 14:02:57

Linux集群技術

2010-01-06 17:12:57

Linux主要構成

2009-07-06 09:17:51

2010-06-28 18:52:49

UML關系符號

2009-07-17 17:02:54

JRuby是什么

2009-10-19 15:07:17

Visual Basi

2011-04-12 15:00:48

Oracle碎片

2009-12-25 16:47:04

Linux Make規

2010-08-04 14:34:35

Flex編程模型

2010-09-25 14:12:50

Java內存分配

2010-10-20 15:11:53

SQL Server作

2016-03-24 14:02:05

ActivityAndroid啟動

2024-11-15 10:58:40

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲午夜久久久 | 午夜在线小视频 | 黄色一级视频 | 久久99网站| 日韩美女在线看免费观看 | 91久操视频 | 亚洲国产精品久久久久久 | 一级a爱片久久毛片 | 国产视频综合 | 国产激情免费视频 | 国产精品免费一区二区 | 美女在线观看av | 一区二区视屏 | 成年人网站免费视频 | 亚洲一区二区三区视频免费观看 | 中文日韩在线 | 成人av一区 | 一区二区成人 | 激情毛片 | 中文字幕电影在线观看 | 久草资源在线 | 亚洲一区二区免费看 | 天天干干 | 午夜在线 | 国产精品国产三级国产aⅴ中文 | 婷婷一级片 | 日本一区高清 | 2021天天干夜夜爽 | 欧美日韩视频在线第一区 | 日韩中文字幕在线 | 免费视频一区二区 | 毛片毛片毛片毛片毛片 | 亚洲电影在线播放 | av网站免费观看 | 天天射影院| 日本成人午夜影院 | 国产精品日本一区二区不卡视频 | 亚洲狠狠 | 影音先锋中文字幕在线观看 | 性生生活大片免费看视频 | 国产日韩欧美激情 |