android面试1

1.生命周期问题

Activity有三个状态: 当它在屏幕前台时(位于当前任务堆栈的顶部),它是激活或运行状态。它就是响应用户操作的Activity。当它上面有另外一个Activity,使它失去了焦点但仍然对用户可见时(如右图),它处于暂停状态。 在它之上的Activity没有完全覆盖屏幕,或者是透明的,被暂停的Activity仍然对用户可见,并且是存活状态(它保留着所有的状态和成员信息并保持和窗口管理器的连接)。如果系统处于内存不足时会杀死这个Activity。当它完全被另一个Activity覆盖时则处于停止状态。它仍然保留所有的状态和成员信息。然而对用户是不可见的,所以它的窗口将被隐藏,如果其它地方需要内存,则系统经常会杀死这个Activity。当Activity从一种状态转变到另一种状态时,会调用以下保护方法来通知这种变化:

void onCreate(Bundle savedInstanceState)、void onStart()、void onRestart()、void onResume()、void onPause()、void onStop()、void onDestroy() 这七个方法定义了Activity的完整生命周期。实现这些方法可以帮助我们监视其中的三个嵌套生命周期循环:

1)的完整生命周期自第一次调用onCreate()开始,直至调用onDestroy()为止。Activity在onCreate()中设置所有“全局”状态以完成初始化,而在onDestroy()中释放所有系统资源。例如,如果Activity有一个线程在后台运行从网络下载数据,它会在onCreate()创建线程,而在 onDestroy() 销毁线程

2)Activity的可视生命周期自onStart()调用开始直到相应的onStop()调用结束。在此期间,用户可以在屏幕上看到Activity,尽管它也许并不是位于前台或者也不与用户进行交互。在这两个方法之间,我们可以保留用来向用户显示这个Activity所需的资源。

3) Activity的前台生命周期自onResume()调用起,至相应的onPause()调用为止。在此期间,Activity位于前台最上面并与用户进行交互。Activity会经常在暂停和恢复之间进行状态转换——例如当设备转入休眠状态或者有新的Activity启动时,将调用onPause() 方法。当Activity获得结果或者接收到新的Intent时会调用onResume() 方法

onCreate()->onStart()->onResume()
当有一个新的Activity打开(完全覆盖):onPause()->onStop()
当有一个新的Activity打开(不完全覆盖):onPause()/<重新启动>onResume()
从新返回前面一个Activity(完全覆盖):onRestart()->onStart()->onResume()
摧毁的生命周期:   onPause()->onStop()->onDestroy()

Activity的onSaveInstanceState()和 onRestoreInstanceState()方法当应用遇到意外情况(如:内存不足、用户直接按Home键)由系统销毁一个Activity时,onSaveInstanceState()会被调用。但是当用户主动去销毁一个Activity时,例如在应用中按返回键,onSaveInstanceState()就不会被调用。因为在这种情况下,用户的行为决定了不需要保存Activity的状态。通常onSaveInstanceState()只适合用于保存一些临时性的状态,而onPause()适合用于数据的持久化保存。另外,当屏幕的方向发生了改变, Activity会被摧毁并且被重新创建,如果你想在Activity被摧毁前缓存一些数据,并且在Activity被重新创建后恢复缓存的数据。可以重写Activity的 onSaveInstanceState() 和onRestoreInstanceState()方法.


5.    请介绍下Android中常用的五种布局。
FrameLayout(框架布局),LinearLayout (线性布局),AbsoluteLayout(绝对布局),RelativeLayout(相对布局),TableLayout(表格布局)
6.    请介绍下Android的数据存储方式。
一.SharedPreferences方式
二.文件存储方式
三.SQLite数据库方式

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

五. 网络存储方式

7.    请介绍下ContentProvider是如何实现数据共享的。
创建一个属于你自己的Content provider或者将你的数据添加到一个已经存在的Content provider中,前提是有相同数据类型并且有写入Content provider的权限。


8.    如何启用Service,如何停用Service。

1)采用Context.startService()方法启动服务有关的生命周期方法onCreate()->onStart()->onDestroy()
onCreate()该方法在服务被创建时调用,该方法只会调用一次,无论调用多少次,停用必须是stopService或者是service内部自己停止
startService()或binService()方法,服务也只被创建一次.
2)采用Context.bindService()方法启动服务有关的生命周期方法         onCreate()->onBind() -> onUnbind() -> onDestroy()

停止的话必须是bind在上面所有的组件都unbind了才可以



9.    注册广播有几种方式,这些方式有何优缺点?请谈谈Android引入广播机制的用意。

        在android下,要想接受广播信息,那么这个广播接收器就得我们自己来实现了,我们可以继承BroadcastReceiver,就可以有一个广播接受器了。有个接受器还不够,我们还得重写BroadcastReceiver里面的onReceiver方法,当来广播的时候我们要干什么,这就要我们自己来实现,不过我们可以搞一个信息防火墙。具体的代码:     

[java] view plaincopy
  1. public class SmsBroadCastReceiver extends BroadcastReceiver      
  2. {       
  3.     @Override    
  4.     public void onReceive(Context context, Intent intent)     
  5.     {     
  6.         Bundle bundle = intent.getExtras();     
  7.         Object[] object = (Object[])bundle.get("pdus");     
  8.         SmsMessage sms[]=new SmsMessage[object.length];     
  9.         for(int i=0;i<object.length;i++)     
  10.         {     
  11.             sms[0] = SmsMessage.createFromPdu((byte[])object[i]);     
  12.             Toast.makeText(context, "来自"+sms[i].getDisplayOriginatingAddress()+" 的消息是:"+sms[i].getDisplayMessageBody(), Toast.LENGTH_SHORT).show();     
  13.         }     
  14.         //终止广播,在这里我们可以稍微处理,根据用户输入的号码可以实现短信防火墙。     
  15.         abortBroadcast();     
  16.     }          
  17. }   

  当实现了广播接收器,还要设置广播接收器接收广播信息的类型,这里是信息:android.provider.Telephony.SMS_RECEIVED

  我们就可以把广播接收器注册到系统里面,可以让系统知道我们有个广播接收器。这里有两种,一种是代码动态注册:

//生成广播处理   
smsBroadCastReceiver = new SmsBroadCastReceiver();   
//实例化过滤器并设置要过滤的广播  

IntentFilter intentFilter = new IntentFilter("android.provider.Telephony.SMS_RECEIVED");

//注册广播   
BroadCastReceiverActivity.this.registerReceiver(smsBroadCastReceiver, intentFilter);  
一种是在AndroidManifest.xml中配置广播

[html] view plaincopy
  1. <?xml version="1.0" encoding="utf-8"?>    
  2. <manifest xmlns:android="http://schemas.android.com/apk/res/android"    
  3.       package="spl.broadCastReceiver"    
  4.       android:versionCode="1"    
  5.       android:versionName="1.0">    
  6.     <application android:icon="@drawable/icon" android:label="@string/app_name">    
  7.         <activity android:name=".BroadCastReceiverActivity"    
  8.                   android:label="@string/app_name">    
  9.             <intent-filter>    
  10.                 <action android:name="android.intent.action.MAIN" />    
  11.                 <category android:name="android.intent.category.LAUNCHER" />    
  12.             </intent-filter>    
  13.         </activity>              
  14.         <!--广播注册-->    
  15.         <receiver android:name=".SmsBroadCastReceiver">    
  16.             <intent-filter android:priority="20">    
  17.                 <action android:name="android.provider.Telephony.SMS_RECEIVED"/>    
  18.             </intent-filter>    
  19.         </receiver>              
  20.     </application>          
  21.     <uses-sdk android:minSdkVersion="7" />          
  22.     <!-- 权限申请 -->    
  23.     <uses-permission android:name="android.permission.RECEIVE_SMS"></uses-permission>         
  24. </manifest>    

  两种注册类型的区别是:

     1)第一种不是常驻型广播,也就是说广播跟随程序的生命周期。

     2)第二种是常驻型,也就是说当应用程序关闭后,如果有信息广播来,程序也会被系统调用自动运行。




  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值