zoukankan      html  css  js  c++  java
  • Android面试题(四)

     38. 请描述下 Activity 的生命周期。 必调用的三个方法:

    onCreate() --> onStart() --> onResume(),

    用 AAA 表示

    (1)父 Activity 启动子 Activity,子 Actvity 退出,父 Activity 调用顺序如下 AAA --> onFreeze() --> onPause() --> onStop() --> onRestart() --> onStart(),onResume() …

    (2)用户点击 Home,Actvity 调用顺序如下 AAA --> onFreeze() --> onPause() --> onStop() -- Maybe --> onDestroy() – Maybe

    (3)调用 finish(), Activity 调用顺序如下 AAA --> onPause() --> onStop() --> onDestroy()

    (4)在 Activity 上显示 dialog, Activity 调用顺序如下 AAA

     (5)在父 Activity 上显示透明的或非全屏的 activity,Activity 调用顺序如下 AAA --> onFreeze() --> onPause()

    (6)设备进入睡眠状态,Activity 调用顺序如下 AAA --> onFreeze() --> onPause()

    41. 如何退出 Activity?如何安全退出已调用多个 Activity 的 Application?

     对于单一 Activity 的应用来说,退出很简单,直接 finish()即可。 当然,也可以用 killProcess()和 System.exit()这样的方法。 但是,对于多 Activity 的应用来说,在打开多个 Activity 后,如果想在最后打开的 Activity 直接退出,上边的方法都是没有用的,因为上边的方法都是结束一个 Activity 而已。 当然,网上也有人说可以。 就好像有人问, 在应用里如何捕获 Home 键, 有人就会说用 keyCode 比较 KEYCODE_HOME 即可,而事实上如果不修改 framework,根本不可能做到这一点一样。 所以,最好还是自己亲自试一下。 那么,有没有办法直接退出整个应用呢? 在 2.1 之前,可以使用 ActivityManager 的 restartPackage 方法。 它可以直接结束整个应用。在使用时需要权限 ndroid.permission.RESTART_PACKAGES。 注意不要被它的名字迷惑。

     可是,在 2.2,这个方法失效了。 在 2.2 添加了一个新的方法,killBackgroundProcesses(),需要权限 android.permission.KILL_BACKGROUND_PROCESSES。 可惜的是,它和 2.2 的 restartPackage 一样,根本起不到应有的效果。 另外还有一个方法,就是系统自带的应用程序管理里,强制结束程序的方法, forceStopPackage()。 它需要权限 android.permission.FORCE_STOP_PACKAGES。 并且需要添加 android:sharedUserId="android.uid.system"属性 同样可惜的是,该方法是非公开的,他只能运行在系统进程,第三方程序无法调用。 因为需要在 Android.mk 中添加 LOCAL_CERTIFICATE := platform。 而 Android.mk 是用于在 Android 源码下编译程序用的。 从以上可以看出,在 2.2,没有办法直接结束一个应用,而只能用自己的办法间接办到。

     现提供几个方法,供参考:

     1、抛异常强制退出: 该方法通过抛异常,使程序 Force Close。 验证可以,但是,需要解决的问题是,如何使程序结束掉,而不弹出 Force Close 的窗口。

     2、记录打开的 Activity: 每打开一个 Activity,就记录下来。在需要退出时,关闭每一个 Activity 即可。

     3、发送特定广播: 在需要结束应用时,发送一个特定的广播,每个 Activity 收到广播后,关闭即可。

     4、递归退出 在打开新的 Activity 时使用 startActivityForResult,然后自己加标志,在 onActivityResult 中 处理,递归关闭。

     除了第一个,都是想办法把每一个 Activity 都结束掉,间接达到目的。 但是这样做同样不完美。 你会发现,如果自己的应用程序对每一个 Activity 都设置了 nosensor,在两个 Activity 结束 的间隙,sensor 可能有效了。 但至少,我们的目的达到了,而且没有影响用户使用。

     为了编程方便,最好定义一个 Activity 基类,处理这些共通问题。

     42. 请介绍下 Android 中常用的五种布局。

     FrameLayout(框架布局),LinearLayout (线性布局),AbsoluteLayout(绝对布局), RelativeLayout(相对布局),TableLayout(表格布局)

     43. 请介绍下 Android 的数据存储方式。

     一.SharedPreferences 方式

     二.文件存储方式

     三.SQLite 数据库方式

     四.内容提供器(Content provider)方式

     五. 网络存储方式

    44. 请介绍下 ContentProvider 是如何实现数据共享的。

     创建一个属于你自己的 Content provider 或者将你的数据添加到一个已经存在的 Content provider 中,前提是有相同数据类型并且有写入 Content provider 的权限。

     45. 如何启用 Service,如何停用 Service。 Android 中的 service 类似于 windows 中的 service,service 一般没有用户操作界面,它运行 于系统中不容易被用户发觉, 可以使用它开发如监控之类的程序。

     一。步骤 第一步:继承 Service 类 public class SMSService extends Service { }

       第二步:在 AndroidManifest.xml 文件中的<application>节点里对服务进行配置: <service android:name=".DemoService" />

     二。Context.startService()和 Context.bindService 服务不能自己运行,需要通过调用 Context.startService()或 Context.bindService()方法启动服 务。这两个方法都可 以启动 Service,但是它们的使用场合有所不同。

       1.使用 startService()方法启用服务,调用者与服务之间没有关连,即使调用者退出了,服务 仍然运行。 使用 bindService()方法启用服务,调用者与服务绑定在了一起,调用者一旦退出,服务也就 终止。

       2.采用 Context.startService()方法启动服务,在服务未被创建时,系统会先调用服务的 onCreate()方法, 接着调用 onStart()方法。 如果调用 startService()方法前服务已经被创建, 多次调用 startService() 方法并 不会导致多次创建服务,但会导致多次调用 onStart()方法。 采用 startService()方法启动的服务,只能调用 Context.stopService()方法结束服务,服务结束 时会调用 onDestroy()方法。

     3.采用 Context.bindService()方法启动服务,在服务未被创建时,系统会先调用服务的 onCreate()方法, 接着调用 onBind()方法。这个时候调用者和服务绑定在一起,调用者退出了,系统就会先调 用服务的 onUnbind()方法, 。接着调用 onDestroy()方法。如果调用 bindService()方法前服务已经被绑定,多次调用 bindService()方法并不会 导致多次创建服务及绑定(也就是说 onCreate()和 onBind()方法并不会被多次调用)。 如果调用 者希望与正在绑定的服务 解除绑定,可以调用 unbindService()方法,调用该方法也会导致系统调用服务的 onUnbind()-->onDestroy()方法。

    三。Service 的生命周期 1.Service 常用生命周期回调方法如下: onCreate() 该方法在服务被创建时调用,该方法只会被调用一次,无论调用多少次 startService()或 bindService()方法, 服务也只被创建一次。 onDestroy()该方法在服务被终止时调用。 2. Context.startService()启动 Service 有关的生命周期方法 onStart() 只有采用 Context.startService()方法启动服务时才会回调该方法。该方法在服务开 始运行时被调用。 多次调用 startService()方法尽管不会多次创建服务,但 onStart() 方法会被多次调用。 3. Context.bindService()启动 Service 有关的生命周期方法 onBind()只有采用 Context.bindService()方法启动服务时才会回调该方法。该方法在调用者与 服务绑定时被调用, 当调用者与服务已经绑定,多次调用 Context.bindService()方法并不会导致该方法被多次调 用。 onUnbind()只有采用 Context.bindService()方法启动服务时才会回调该方法。 该方法在调用者 与服务解除绑定时被调用。 备注: 1. 采用 startService()启动服务 Intent intent = new Intent(DemoActivity.this, DemoService.class); startService(intent); 2.Context.bindService()启动 Intent intent = new Intent(DemoActivity.this, DemoService.class); bindService(intent, conn, Context.BIND_AUTO_CREATE); //unbindService(conn);//解除绑定

  • 相关阅读:
    FL2440-学习记录(二)
    FL2440-学习记录(三)
    C专家编程 第一章
    C陷阱与缺陷
    ARM体系结构与编程-第二章
    二叉堆 及 大根堆的python实现
    八皇后问题
    非递归全排列 python实现
    Python 学习
    poj1064 Cable master(二分查找,精度)
  • 原文地址:https://www.cnblogs.com/liuzenglong/p/2221051.html
Copyright © 2011-2022 走看看