当前位置:  编程技术>移动开发
本页文章导读:
    ▪Activity详解(生命周期、以各种方式起动Activity、状态保存,完全退出等)        Activity详解(生命周期、以各种方式启动Activity、状态保存,完全退出等)一、什么是Activity?     简单的说:Activity就是布满整个窗口或者悬浮于其他窗口上的交互界面。在一个应用程序中.........
    ▪ 欧盟状告微软未遵守承诺提供浏览器选择        欧盟指控微软未遵守承诺提供浏览器选择 10月25日消息,据华尔街日报报道,欧盟委员会周三指控微软未遵守向Windows用户提供浏览器选择的承诺,微软可能将面临高达74亿美元的罚款。 三.........
    ▪ 内核间断       内核中断 #include <linux/interrupt.h> int request_irq(unsigned int irq, irq_handler_t handler,   unsigned long irqflags, const char *devname, void *dev_id)  irq:   中断号 arch/arm/mach-s3c64xx/include/mach/irqs.h  handler:   中.........

[1]Activity详解(生命周期、以各种方式起动Activity、状态保存,完全退出等)
    来源: 互联网  发布时间: 2014-02-18
Activity详解(生命周期、以各种方式启动Activity、状态保存,完全退出等)
一、什么是Activity?

    简单的说:Activity就是布满整个窗口或者悬浮于其他窗口上的交互界面。在一个应用程序中通常由多个Activity构成,都会在Manifest.xml中指定一个主的Activity,如下设置

view source
print?
1 <activity
2        android:label="@string/app_name"
3        android:name=".MainActivity" >
4           <intent-filter >
5               <action android:name="android.intent.action.MAIN" />
6               <category android:name="android.intent.category.LAUNCHER" />
7           </intent-filter>
8  </activity>


当程序第一次运行时用户就会看这个Activity,这个Activity可以通过启动其他的Activity进行相关操作。当启动其他的Activity时这个当前的这个Activity将会停止,新的Activity将会压入栈中,同时获取用户焦点,这时就可在这个Activity上操作了。都知道栈是先进后出的原则,那么当用户按Back键时,当前的这个Activity销毁,前一个Activity重新恢复。

二、Activity生命周期

先看下图:


这个图不再多说什么,下面我们通过一个实例来说明问题。新建工程,编写如下代码:

view source
print?
01 package com.android.ttx.actiitylifedemo;
02 import android.app.Activity;
03 import android.os.Bundle;
04 import android.util.Log;
05 import android.view.KeyEvent;
06 public class ActivityLifeDemo extends Activity {
07     private final static String TAG="ActivityLifeDemo";
08       
09     @Override
10     public void onCreate(Bundle savedInstanceState) {
11         super.onCreate(savedInstanceState);
12         setContentView(R.layout.main);
13           
14         Log.i(TAG, "onCreate");
15     }
16     @Override
17     protected void onStart() {
18         Log.i(TAG, "onStart");
19         super.onStart();
20     }
21     @Override
22     protected void onRestart() {
23         Log.i(TAG, "onRestart");
24         super.onRestart();
25     }
26     @Override
27     protected void onResume() {
28         Log.i(TAG, "onResume");
29         super.onResume();
30     }
31     @Override
32     protected void onPause() {
33         Log.i(TAG, "onPause");
34         super.onPause();
35     }
36     @Override
37     protected void onStop() {
38         Log.i(TAG, "onStop");
39         super.onStop();
40     }
41     @Override
42     protected void onDestroy() {
43         Log.i(TAG, "onDestroy");
44         super.onDestroy();
45     }
46 }

代码很简单,只涉及到一个Activity,一些用户的操作,我们通过记录操作和打印日志的方式来看看Activity的生命周期过程。

1、  运行
看到如下打印日志:
08-31 08:46:53.916: INFO/ActivityLifeDemo(312): onCreate
08-31 08:46:53.916: INFO/ActivityLifeDemo(312): onStart
08-31 08:46:53.916: INFO/ActivityLifeDemo(312): onResume
2、按下返回按键: 
08-31 09:29:57.396: INFO/ActivityLifeDemo(354): onPause
08-31 09:29:58.216: INFO/ActivityLifeDemo(354): onStop
08-31 09:29:58.216: INFO/ActivityLifeDemo(354): onDestroy
3、长按Home键,弹出最近打开过的应用程序,点击ActivityLifeDemo
08-31 08:51:46.916: INFO/ActivityLifeDemo(312): onCreate
08-31 08:51:46.916: INFO/ActivityLifeDemo(312): onStart
08-31 08:51:46.936: INFO/ActivityLifeDemo(312): onResume
4、按Home键
08-31 08:53:32.676: INFO/ActivityLifeDemo(312): onPause
08-31 08:53:33.796: INFO/ActivityLifeDemo(312): onStop
5、在AllList中点击打开
08-31 08:54:14.286: INFO/ActivityLifeDemo(312): onRestart
08-31 08:54:14.286: INFO/ActivityLifeDemo(312): onStart
08-31 08:54:14.296: INFO/ActivityLifeDemo(312): onResume

通过日志信息,我们可以看到。Activity的启动过程:onCreate—onStart—onResume;下返回键时:onPause—onStop—onDestroy 正如上面说是,当按下返回键时,此Activity弹出栈,程序销毁。确实如此,我们再次 打开时的启动过程又回到onCreate—onStart—onResume。OK,启动之后按下Home键,回到Launcher,查看打印信息:onPause—onStop,再次打开的运行过程:onRestart—onStart—onResume。

我们通过对Activity的各种操作,构成了Activity的生命周期,我们看到无论对Activity做如何的操作,都会接收到相关的回调方法,那么我们在开发的过程中通过这些回调方法就可以写工作,比如说释放一些重量级的对象,网络连接,数据库连接,文件读等等。

以下是各个方法的详细说明:

onCreate():当 activity 第一次创建时会被调用。在这个方法中你需要完成所有的正常静态设置 ,比如创建一个视图( view )、绑定列表的数据等等。如果能捕获到 activity 状态的话,这个方法传递进来的 Bundle 对象将存放了 activity 当前的状态。调用该方法后一般会调用 onStart() 方法。

onRestart():在 activity 被停止后重新启动时会调用该方法。其后续会调用 onStart 方法。

onStart()à当 activity 对于用户可见前即调用这个方法。如果 activity回到前台则接着调用 onResume() ,如果 activity 隐藏则调用onStop()

onResume():在 activity 开始与用户交互前调用该方法。在这时该activity 处于 activity 栈的顶部,并且接受用户的输入。其后续会调用 onPause() 方法。

onPause():在系统准备开始恢复其它 activity 时会调用该方法。这个方法中通常用来提交一些还没保存的更改到持久数据 中,停止一些动画或其它一些耗 CPU 的操作等等。无论在该方法里面进行任何操作,都需要较快速完成,因为如果它不返回的话,下一个 activity 将无法恢复出来。如果 activity 返回到前台将会调用 onResume() ,如果 activity 变得对用户不可见了将会调用onStop() 。

onStop():在 activity 对用户不可见时将调用该方法。可能会因为当前 activity 正在被销毁,或另一个 activity (已经存在的activity 或新的 activity )已经恢复了正准备覆盖它,而调用该方法。如果 activity 正准备返回与用户交互时后续会调用onRestart ,如果 activity 正在被释放则会调用 onDestroy 。

onDestroy():在 activity 被销毁前会调用该方法。这是 activity 能接收到的最后一个调用。可能会因为有人调用了 finish 方法使得当前activity 正在关闭,或系统为了保护内存临时释放这个 activity的实例,而调用该方法。你可以用 isFinishing 方法来区分这两种不同的情况。

三、如何启动一个新的Activity?

要启动一个新的Activity,我们可以通过调用Context中的startActivity来启动。像这样:

view source
print?
1 Intent intent = new Intent(this, ActivityDemo.class);
2 startActivity(intent);  // ActivityDemo是需要启动的Activity类

通过上面的方法可以启动新的Activity了,但如果我要从当前的Activity中传递数据到新的Activity呢?很简单:

view source
print?
1 Intent intent = new Intent(this,ActivityDemo.class);
2 Bundle bundle = new Bundle();
3 bundle.putBoolean("bool_key", true);
4 intent.putExtras(bundle);
5 startActivity(intent);

还有,有时候我们需要启动带返回值的Activity,简单的说就是需要新启动的Activity返回时将值传递给启动它的Activity,像这样:

view source
print?
1 Intent intent = new Intent(ActivityLifeDemo.this,RevalueActivity.class);
2 startActivityForResult(intent, 0x1001);

ActivityLifeDemo是当前的Activity,启动RevalueActivity,我们在ActivityLifeDemo中需要获取RevalueActivity传回来的值。那么在RevalueActivity中就必须这样写:

view source
print?
1 Intent intent  = new Intent();
2 intent.putExtra("revalue_key","haha-revalueActivity");
3 setResult(0x1001, intent);

那么“revalue_key”值在哪里获取呢?必须重写onActivityResult方法,通过判断requestCode,来确定:

view source
print?
1 if(requestCode==0x1001){
2     String str = data.getStringExtra("revalue_key");
3         Log.i(TAG, "返回的值为:"+str);
4         }

四、保存Activity运行状态

通过重写onSaveInstanceState()方法来实现Activity的运行状态,请注意以下几点:

1)由于activity 对象被暂停或停止时,它仍然保留在内存里面,关于它的成员信息和当前状态都是活动的,所以此时可以保存Activity的状态,从而使用户所作的Activity的更改保存在内存中

2)  当系统回收内存而将Activity销毁时,就无法保存其状态,所以需要调用onSaveInstanceState()方法来实现状态的保存

3)  很多情况并不需要保持状态信息,比如按下返回键直接关闭程序,所以并不能保证会调用onSaveInstanceState。如果调用了该方法,一般是在onStop 方法之前且可能在 onPause 之后调用。尽管如此,即使你没做任何操作或没有实现 onSaveInstanceState() 方法,你的 activity 状态也能通过Activity 类里面默认实现的 onSaveInstanceState 方法恢复出来。特别是会为布局中的视图( View )默认调用onSaveInstanceState 方法,并在这个方法中允许每一个视图提供它需要恢复的任何信息。几乎每一个 Android框架中的 widget 都视情况实现了这个方法。

注:因为 onSaveInstanceState 方法不一定会被调用,所以你应该只是用它来保存一些 activity 的转换过程状态(即 UI 的状态),而不能用来保存永久性数据。但你可以用 onPause 方法在用户离开 activity 时来保存永久性数据,比如需要保存到数据库的数据。

有一个很好的方法可以用来检验应用程序保存状态的能力,就是简单地旋转你的设备来改变屏幕的方向。因为当屏幕方向改变时,系统为了给新的方向提供一个可能合适的代替资源,会销毁 activity 并新建一个新的。由于这个原因,你的 activity 是否能在其重新创建时完成保存状态就显得尤为重要,因为用户经常会在使用应用程序时旋转屏幕的。

五、完全退出程序

通过上面的介绍,我们知道当点击back键时,程序调用了onDestroy方法,程序退出了,但是我们查看其进程,发现调用了onDestroy方法之后这个Activity还在运行。甚至调用了finish()方法之后程序还能在进程中看到。通过下面这种方式可以实现程序的完全退出:

view source
print?
1 Intent intent = new Intent();
2 Intent.setClass(context,MainActivity.class);
3 intent.setFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP);
4 intent.putExtra(“flag”,EXIT_APPLICATION);
5 context.startActivity(intnet);

    
[2] 欧盟状告微软未遵守承诺提供浏览器选择
    来源: 互联网  发布时间: 2014-02-18
欧盟指控微软未遵守承诺提供浏览器选择

10月25日消息,据华尔街日报报道,欧盟委员会周三指控微软未遵守向Windows用户提供浏览器选择的承诺,微软可能将面临高达74亿美元的罚款。

三年前,微软与欧盟委员会达成协议,同意为用户提供浏览器选择权,以解决公司面临的反垄断调查以及可能高达该公司全球营业额10%的罚款。

但欧盟委员会(即欧盟反垄断机构)今年7月表示,微软自去年2月以来未能遵守这一约定。微软将此归咎于技术问题。

微软可能面临着巨额罚款,因为这是该公司第二次未遵守与欧盟的决定。

罚款可能高达74亿美元,或截至2012年6月30日财年收入10%。但最终罚款预计可能会稍低,因为侵权行为只有一段很短的时间。

在过去十年里,微软向欧盟监管机构上缴的罚款已超过十亿欧元。


    
[3] 内核间断
    来源: 互联网  发布时间: 2014-02-18
内核中断


#include <linux/interrupt.h>

int request_irq(unsigned int irq, irq_handler_t handler,
  unsigned long irqflags, const char *devname, void *dev_id)

 irq:
  中断号 arch/arm/mach-s3c64xx/include/mach/irqs.h

 handler:
  中断处理函数 irqreturn_t handler(int irq, void *dev_id);
  irqreturn_t:
   See include/linux/irqreturn.h

 irqflags:
  See line 21-59 in include/linux/interrupt.h
  使用IRQF_SHARED共享irq时, irqflags必须相同
  如:   request_irq(IRQ_EINT(0), handler1,
    IRQF_TRIGGER_FALLING | IRQF_SHARED, "dev1", &dev1);

   request_irq(IRQ_EINT(0), handler2,
    IRQF_TRIGGER_FALLING | IRQF_SHARED, "dev2", &dev2);

 devname:
  设备名, cat /proc/interrupts

 dev_id:
  发生中断时将dev_id传递给handler函数,
         irqflags含有IRQF_SHARED时dev_id不能为NULL, 并且要保证唯一
  dev_id一般采用当前设备的结构体指针


void free_irq ( unsigned int irq, void * dev_id);
 释放匹配irq和dev_id的中断, 如果irq有多个相同的dev_id, 将释放第一个
 So, 共享中断的dev_id不是唯一时, 可能会释放到其它设备的中断


void disable_irq(unsigned int irq);
 关闭irq号中断 

void enable_irq(unsigned int irq);
 开启irq号中断 

void local_irq_save(unsigned long flags);
 关闭当前CPU中断并保存当前状态到flags

void local_irq_restore(unsigned long flags);
 恢复flags到当前CPU

void local_irq_disable(void);
 关闭当前CPU中断

void local_irq_enable(void);
 开启当前CPU中断

注: 没有关闭和开启所有CPU中断的函数(没必要)

 


    
最新技术文章:
▪Android开发之登录验证实例教程
▪Android开发之注册登录方法示例
▪Android获取手机SIM卡运营商信息的方法
▪Android实现将已发送的短信写入短信数据库的...
▪Android发送短信功能代码
▪Android根据电话号码获得联系人头像实例代码
▪Android中GPS定位的用法实例
▪Android实现退出时关闭所有Activity的方法
▪Android实现文件的分割和组装
▪Android录音应用实例教程
▪Android双击返回键退出程序的实现方法
▪Android实现侦听电池状态显示、电量及充电动...
▪Android获取当前已连接的wifi信号强度的方法
▪Android实现动态显示或隐藏密码输入框的内容
▪根据USER-AGENT判断手机类型并跳转到相应的app...
▪Android Touch事件分发过程详解
▪Android中实现为TextView添加多个可点击的文本
▪Android程序设计之AIDL实例详解
▪Android显式启动与隐式启动Activity的区别介绍
▪Android按钮单击事件的四种常用写法总结
▪Android消息处理机制Looper和Handler详解
▪Android实现Back功能代码片段总结
▪Android实用的代码片段 常用代码总结
▪Android实现弹出键盘的方法
▪Android中通过view方式获取当前Activity的屏幕截...
▪Android提高之自定义Menu(TabMenu)实现方法
▪Android提高之多方向抽屉实现方法
▪Android提高之MediaPlayer播放网络音频的实现方法...
▪Android提高之MediaPlayer播放网络视频的实现方法...
▪Android提高之手游转电视游戏的模拟操控
 


站内导航:


特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

©2012-2021,,E-mail:www_#163.com(请将#改为@)

浙ICP备11055608号-3