收藏 分销(赏)

2023年Android面试整里大全.doc

上传人:二*** 文档编号:4710079 上传时间:2024-10-10 格式:DOC 页数:89 大小:234.04KB
下载 相关 举报
2023年Android面试整里大全.doc_第1页
第1页 / 共89页
亲,该文档总共89页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述

1、1、 Android的四大组件是哪些,它们的作用?答:Activity:Activity是Android程序与用户交互的窗口,是Android构造块中最基本的一种,它需要为保持各界面的状态,做很多持久化的事情,妥善管理生命周期以及一些跳转逻辑service:后台服务于Activity,封装有一个完整的功能逻辑实现,接受上层指令,完毕相关的事物,定义好需要接受的Intent提供同步和异步的接口Content Provider:是Android提供的第三方应用数据的访问方案,可以派生Content Provider类,对外提供数据,可以像数据库同样进行选择排序,屏蔽内部数据的存储细节,向外提供统一

2、的接口模型,大大简化上层应用,对数据的整合提供了更方便的途径BroadCast Receiver:接受一种或者多种Intent作触发事件,接受相关消息,做一些简朴解决,转换成一条Notification,统一了Android的事件广播模型2、 请介绍下Android中常用的五种布局。常用五种布局方式,分别是:FrameLayout(框架布局),LinearLayout (线性布局),AbsoluteLayout(绝对布局),RelativeLayout(相对布局),TableLayout(表格布局)。一、FrameLayout:所有东西依次都放在左上角,会重叠,这个布局比较简朴,也只能放一点比

3、较简朴的东西。二、LinearLayout:线性布局,每一个LinearLayout里面又可分为垂直布局(android:orientation=vertical)和水平布局(android:orientation=horizontal )。当垂直布局时,每一行就只有一个元素,多个元素依次垂直往下;水平布局时,只有一行,每一个元素依次向右排列。三、AbsoluteLayout:绝对布局用X,Y坐标来指定元素的位置,这种布局方式也比较简朴,但是在屏幕旋转时,往往会出问题,并且多个元素的时候,计算比较麻烦。四、RelativeLayout:相对布局可以理解为某一个元素为参照物,来定位的布局方式。重

4、要属性有:相对于某一个元素android:layout_below、 android:layout_toLeftOf相对于父元素的地方android:layout_alignParentLeft、android:layout_alignParentRigh;五、TableLayout:表格布局,每一个TableLayout里面有表格行TableRow,TableRow里面可以具体定义每一个元素。每一个布局都有自己适合的方式,这五个布局元素可以互相嵌套应用,做出美观的界面。3、 android中的动画有哪几类,它们的特点和区别是什么 答:两种,一种是Tween动画、尚有一种是Frame动画。Tw

5、een动画,这种实现方式可以使视图组件移动、放大、缩小以及产生透明度的变化;另一种Frame动画,传统的动画方法,通过顺序的播放排列好的图片来实现,类似电影。4、 android 中有哪几种解析xml的类?官方推荐哪种?以及它们的原理和区别。答:XML解析重要有三种方式,SAX、DOM、PULL。常规在PC上开发我们使用Dom相对轻松些,但一些性能敏感的数据库或手机上还是重要采用SAX方式,SAX读取是单向的,优点:不占内存空间、解析属性方便,但缺陷就是对于套嵌多个分支来说解决不是很方便。而DOM方式会把整个XML文献加载到内存中去,该方法在查找方面可以和XPath很好的结合假如数据量不是很大

6、推荐使用,而PULL经常用在J2ME对于节点解决比较好,类似SAX方式,同样很节省内存,在J2ME中我们经常使用的KXML库来解析。5、 ListView的优化方案答:1、假如自定义适配器,那么在getView方法中要考虑方法传进来的参数contentView是否为null,假如为null就创建contentView并返回,假如不为null则直接使用。在这个方法中尽也许少创建view。2、给contentView设立tag(setTag(),传入一个viewHolder对象,用于缓存要显示的数据,可以达成图像数据异步加载的效果。3、假如listview需要显示的item很多,就要考虑分页加载。

7、比如一共要显示100条或者更多的时候,我们可以考虑先加载20条,等用户拉到列表底部的时候再去加载接下来的20条。6、 请介绍下Android的数据存储方式。答:使用SharedPreferences存储数据;文献存储数据;SQLite数据库存储数据;使用ContentProvider存储数据;网络存储数据;Preference,File, DataBase这三种方式分别相应的目录是/data/data/Package Name/Shared_Pref, /data/data/Package Name/files, /data/data/Package Name/database 。一:使用Sh

8、aredPreferences存储数据一方面说明SharedPreferences存储方式,它是 Android提供的用来存储一些简朴配置信息的一种机制,例如:登录用户的用户名与密码。其采用了Map数据结构来存储数据,以键值的方式存储,可以简朴的读取与写入,具体实例如下:void ReadSharedPreferences()String strName,strPassword;SharedPreferences user = getSharedPreferences(“user_info”,0);strName = user.getString(“NAME”,”);strPassword =

9、 user getString(“PASSWORD”,”);void WriteSharedPreferences(String strName,String strPassword)SharedPreferences user = getSharedPreferences(“user_info”,0);uer.edit();user.putString(“NAME”, strName);user.putString(“PASSWORD” ,strPassword);mit();数据读取与写入的方法都非常简朴,只是在写入的时候有些区别:先调用edit()使其处在编辑状态,然后才干修改数据,最后

10、使用commit()提交修改的数据。事实上SharedPreferences是采用了XML格式将数据存储到设备中,在DDMS中的File Explorer中的/data/data/shares_prefs下。使用SharedPreferences是有些限制的:只能在同一个包内使用,不能在不同的包之间使用。7、 二:文献存储数据文献存储方式是一种较常用的方法,在Android中读取/写入文献的方法,与 Java中实现I/O的程序是完全同样的,提供了openFileInput()和openFileOutput()方法来读取设备上的文献。具体实例如下:String fn = “moandroid.l

11、og”;FileInputStream fis = openFileInput(fn);FileOutputStream fos = openFileOutput(fn,Context.MODE_PRIVATE);三:网络存储数据网络存储方式,需要与Android 网络数据包打交道,关于Android 网络数据包的具体说明,请阅读Android SDK引用了Java SDK的哪些package?。四:ContentProvider1、ContentProvider简介当应用继承ContentProvider类,并重写该类用于提供数据和存储数据的方法,就可以向其他应用共享其数据。虽然使用其他方法

12、也可以对外共享数据,但数据访问方式会因数据存储的方式而不同,如:采用文献方式对外共享数据,需要进行文献操作读写数据;采用sharedpreferences共享数据,需要使用sharedpreferences API读写数据。而使用ContentProvider共享数据的好处是统一了数据访问方式。2、Uri类简介Uri代表了要操作的数据,Uri重要包含了两部分信息:1.需要操作的ContentProvider ,2.对ContentProvider中的什么数据进行操作,一个Uri由以下几部分组成:1.scheme:ContentProvider(内容提供者)的scheme已经由Android所规

13、定为:content:/2.主机名(或Authority):用于唯一标记这个ContentProvider,外部调用者可以根据这个标记来找到它。3.途径(path):可以用来表达我们要操作的数据,途径的构建应根据业务而定,如下:要操作contact表中id为10的记录,可以构建这样的途径:/contact/10要操作contact表中id为10的记录的name字段, contact/10/name要操作contact表中的所有记录,可以构建这样的途径:/contact?要操作的数据不一定来自数据库,也可以是文献等他存储方式,如下:要操作xml文献中contact节点下的name节点,可以构建这

14、样的途径:/contact/name假如要把一个字符串转换成Uri,可以使用Uri类中的parse()方法,如下:Uri uri = Uri.parse(content:/com.changcheng.provider.contactprovider/contact)3、UriMatcher、ContentUrist和ContentResolver简介由于Uri代表了要操作的数据,所以我们很经常需要解析Uri,并从 Uri中获取数据。Android系统提供了两个用于操作Uri的工具类,分别为UriMatcher 和ContentUris 。掌握它们的使用,会便于我们的开发工作。UriMatch

15、er:用于匹配Uri,它的用法如下:1.一方面把你需要匹配Uri途径所有给注册上,如下:/常量UriMatcher.NO_MATCH表达不匹配任何途径的返回码(-1)。UriMatcher uriMatcher = new UriMatcher(UriMatcher.NO_MATCH);/假如match()方法匹配content:/com.changcheng.sqlite.provider.contactprovider /contact途径,返回匹配码为1uriMatcher.addURI(“com.changcheng.sqlite.provider.contactprovider”,

16、“contact”, 1);/添加需要匹配uri,假如匹配就会返回匹配码/假如match()方法匹配 content:/com.changcheng.sqlite.provider.contactprovider/contact/230途径,返回匹配码为2uriMatcher.addURI(“com.changcheng.sqlite.provider.contactprovider”, “contact/#”, 2);/#号为通配符2.注册完需要匹配的Uri后,就可以使用uriMatcher.match(uri)方法对输入的Uri进行匹配,假如匹配就返回匹配码,匹配码是调用 addURI()

17、方法传入的第三个参数,假设匹配 content:/com.changcheng.sqlite.provider.contactprovider/contact途径,返回的匹配码为1。ContentUris:用于获取Uri途径后面的ID部分,它有两个比较实用的方法:withAppendedId(uri, id)用于为途径加上ID部分parseId(uri)方法用于从途径中获取ID部分ContentResolver:当外部应用需要对ContentProvider中的数据进行添加、删除、修改和查询操作时,可以使用 ContentResolver 类来完毕,要获取ContentResolver 对象,

18、可以使用Activity提供的getContentResolver()方法。 ContentResolver使用insert、delete、update、query方法,来操作数据。8、 activity的启动模式有哪些?是什么含义?答:在android里,有4种activity的启动模式,分别为: “standard” (默认) “singleTop” “singleTask” “singleInstance”它们重要有如下不同:9、 1. 如何决定所属task “standard”和”singleTop”的activity的目的task,和收到的Intent的发送者在同一个task内,除非

19、intent涉及参数FLAG_ACTIVITY_NEW_TASK。 假如提供了FLAG_ACTIVITY_NEW_TASK参数,会启动到别的task里。 “singleTask”和”singleInstance”总是把activity作为一个task的根元素,他们不会被启动到一个其他task里。2. 是否允许多个实例 “standard”和”singleTop”可以被实例化多次,并且存在于不同的task中,且一个task可以涉及一个activity的多个实例; “singleTask”和”singleInstance”则限制只生成一个实例,并且是task的根元素。 singleTop规定假如创

20、建intent的时候栈顶已有要创建 的Activity的实例,则将intent发送给该实例,而不发送给新的实例。3. 是否允许其它activity存在于本task内 “singleInstance”独占一个task,其它activity不能存在那个task里;假如它启动了一个新的activity,不管新的activity的launch mode 如何,新的activity都将会到别的task里运营(如同加了FLAG_ACTIVITY_NEW_TASK参数)。 而此外三种模式,则可以和其它activity共存。4. 是否每次都生成新实例 “standard”对于没一个启动Intent都会生成一个

21、activity的新实例; “singleTop”的activity假如在task的栈顶的话,则不生成新的该activity的实例,直接使用栈顶的实例,否则,生成该activity的实例。 比如现在task栈元素为A-B-C-D(D在栈顶),这时候给D发一个启动intent,假如D是 “standard”的,则生成D的一个新实例,栈变为ABCDD。 假如D是singleTop的话,则不会生产D的新实例,栈状态仍为A-B-C-D 假如这时候给B发Intent的话,不管B的launchmode是”standard” 还是 “singleTop” ,都会生成B的新实例,栈状态变为A-B-C-D-B。

22、“singleInstance”是其所在栈的唯一activity,它会每次都被重用。“singleTask”假如在栈顶,则接受intent,否则,该intent会被丢弃,但是该task仍会回到前台。当已经存在的activity实例解决新的intent时候,会调用onNewIntent()方法 假如收到intent生成一个activity实例,那么用户可以通过back键回到上一个状态;假如是已经存在的一个activity来解决这个intent的话,用户不能通过按back键返回到这之前的状态。10、 跟activity和Task 有关的 Intent启动方式有哪些?其含义?核心的Intent Fl

23、ag有: FLAG_ACTIVITY_NEW_TASK FLAG_ACTIVITY_CLEAR_TOP FLAG_ACTIVITY_RESET_TASK_IF_NEEDED FLAG_ACTIVITY_SINGLE_TOPFLAG_ACTIVITY_NEW_TASK 假如设立,这个Activity会成为历史stack中一个新Task的开始。一个Task(从启动它的Activity到下一个Task中的 Activity)定义了用户可以迁移的Activity原子组。Task可以移动到前台和后台;在某个特定Task中的所有Activity总是保持相同的顺序。 这个标志一般用于呈现“启动”类型的行为:

24、它们提供用户一系列可以单独完毕的事情,与启动它们的Activity完全无关。 使用这个标志,假如正在启动的Activity的Task已经在运营的话,那么,新的Activity将不会启动;代替的,当前Task会简朴的移入前台。参考FLAG_ACTIVITY_MULTIPLE_TASK标志,可以禁用这一行为。 这个标志不能用于调用方对已经启动的Activity请求结果。FLAG_ACTIVITY_CLEAR_TOP 假如设立,并且这个Activity已经在当前的Task中运营,因此,不再是重新启动一个这个Activity的实例,而是在这个Activity上方的所有Activity都将关闭,然后这个

25、Intent会作为一个新的Intent投递到老的Activity(现在位于顶端)中。 例如,假设一个Task中包含这些Activity:A,B,C,D。假如D调用了startActivity(),并且包含一个指向Activity B的Intent,那么,C和D都将结束,然后B接受到这个Intent,因此,目前stack的状况是:A,B。 上例中正在运营的Activity B既可以在onNewIntent()中接受到这个新的Intent,也可以把自己关闭然后重新启动来接受这个Intent。假如它的启动模式声明为 “multiple”(默认值),并且你没有在这个Intent中设立FLAG_ACTI

26、VITY_SINGLE_TOP标志,那么它将关闭然后重新创建;对于其它的启动模式,或者在这个Intent中设立FLAG_ACTIVITY_SINGLE_TOP标志,都将把这个Intent投递到当前这个实例的onNewIntent()中。 这个启动模式还可以与FLAG_ACTIVITY_NEW_TASK结合起来使用:用于启动一个Task中的根Activity,它会把那个Task中任何运营的实例带入前台,然后清除它直到根Activity。这非常有用,例如,当从Notification Manager处启动一个Activity。 FLAG_ACTIVITY_RESET_TASK_IF_NEEDED

27、假如设立这个标志,这个activity不管是从一个新的栈启动还是从已有栈推到栈顶,它都将以the front door of the task的方式启动。这就讲导致任何与应用相关的栈都讲重置到正常状态(不管是正在讲activity移入还是移除),假如需要,或者直接重置该栈为初始状态。FLAG_ACTIVITY_SINGLE_TOP 假如设立,当这个Activity位于历史stack的顶端运营时,不再启动一个新的FLAG_ACTIVITY_BROUGHT_TO_FRONT 这个标志一般不是由程序代码设立的,如在launchMode中设立singleTask模式时系统帮你设定。 FLAG_ACTI

28、VITY_CLEAR_WHEN_TASK_RESET 假如设立,这将在Task的Activity stack中设立一个还原点,当Task恢复时,需要清理Activity。也就是说,下一次Task带着 FLAG_ACTIVITY_RESET_TASK_IF_NEEDED标记进入前台时(典型的操作是用户在主画面重启它),这个Activity和它之上的都将关闭,以至于用户不能再返回到它们,但是可以回到之前的Activity。 这在你的程序有分割点的时候很有用。例如,一个e-mail应用程序也许有一个操作是查看一个附件,需要启动图片浏览Activity来显示。这个 Activity应当作为e-mail

29、应用程序Task的一部分,由于这是用户在这个Task中触发的操作。然而,当用户离开这个Task,然后从主画面选择e-mail app,我们也许希望回到查看的会话中,但不是查看图片附件,由于这让人困惑。通过在启动图片浏览时设定这个标志,浏览及其它启动的Activity在下次用户返回到mail程序时都将所有清除。 FLAG_ACTIVITY_EXCLUDE_FROM_RECENTS 假如设立,新的Activity不会在最近启动的Activity的列表中保存。 FLAG_ACTIVITY_FORWARD_RESULT 假如设立,并且这个Intent用于从一个存在的Activity启动一个新的Acti

30、vity,那么,这个作为答复目的的Activity将会传到这个新的Activity中。这种方式下,新的Activity可以调用setResult(int),并且这个结果值将发送给那个作为答复目的的 Activity。 FLAG_ACTIVITY_LAUNCHED_FROM_HISTORY 这个标志一般不由应用程序代码设立,假如这个Activity是从历史记录里启动的(常按HOME键),那么,系统会帮你设定。 FLAG_ACTIVITY_MULTIPLE_TASK 不要使用这个标志,除非你自己实现了应用程序启动器。与FLAG_ACTIVITY_NEW_TASK结合起来使用,可以禁用把已存的Tas

31、k送入前台的行为。当设立时,新的Task总是会启动来解决Intent,而不管这是是否已有一个Task可以解决相同的事情。 由于默认的系统不包含图形Task管理功能,因此,你不应当使用这个标志,除非你提供应用户一种方式可以返回到已经启动的Task。 假如FLAG_ACTIVITY_NEW_TASK标志没有设立,这个标志被忽略。 FLAG_ACTIVITY_NO_ANIMATION 假如在Intent中设立,并传递给Context.startActivity()的话,这个标志将阻止系统进入下一个Activity时应用 Acitivity迁移动画。这并不意味着动画将永不运营假如另一个Activity

32、在启动显示之前,没有指定这个标志,那么,动画将被应用。这个标志可以很好的用于执行一连串的操作,而动画被看作是更高一级的事件的驱动。 FLAG_ACTIVITY_NO_HISTORY 假如设立,新的Activity将不再历史stack中保存。用户一离开它,这个Activity就关闭了。这也可以通过设立noHistory特性。 FLAG_ACTIVITY_NO_USER_ACTION 假如设立,作为新启动的Activity进入前台时,这个标志将在Activity暂停之前阻止从最前方的Activity回调的onUserLeaveHint()。 典型的,一个Activity可以依赖这个回调指明显式的用

33、户动作引起的Activity移出后台。这个回调在Activity的生命周期中标记一个合适的点,并关闭一些Notification。 假如一个Activity通过非用户驱动的事件,如来电或闹钟,启动的,这个标志也应当传递给Context.startActivity,保证暂停的Activity不认为用户已经知晓其Notification。 FLAG_ACTIVITY_PREVIOUS_IS_TOP If set and this intent is being used to launch a new activity from an existing one, the current activ

34、ity will not be counted as the top activity for deciding whether the new intent should be delivered to the top instead of starting a new one. The previous activity will be used as the top, with the assumption being that the current activity will finish itself immediately. FLAG_ACTIVITY_REORDER_TO_FR

35、ONT 假如在Intent中设立,并传递给Context.startActivity(),这个标志将引发已经运营的Activity移动到历史stack的顶端。 例如,假设一个Task由四个Activity组成:A,B,C,D。假如D调用startActivity()来启动Activity B,那么,B会移动到历史stack的顶端,现在的顺序变成A,C,D,B。假如FLAG_ACTIVITY_CLEAR_TOP标志也设立的话,那么这个标志将被忽略。 11、 请描述下Activity的生命周期。答:activity的生命周期方法有:onCreate()、onStart()、onReStart()、

36、onResume()、onPause()、onStop()、onDestory();可见生命周期:从onStart()直到系统调用onStop()前台生命周期:从onResume()直到系统调用onPause()12、 activity在屏幕旋转时的生命周期答:不设立Activity的android:configChanges时,切屏会重新调用各个生命周期,切横屏时会执行一次,切竖屏时会执行两次;设立Activity的android:configChanges=orientation时,切屏还是会重新调用各个生命周期,切横、竖屏时只会执行一次;设立Activity的android:config

37、Changes=orientation|keyboardHidden时,切屏不会重新调用各个生命周期,只会执行onConfigurationChanged方法13、 如何启用Service,如何停用Service。服务的开发比较简朴,如下:第一步:继承Service类public class SMSService extends Service 第二步:在AndroidManifest.xml文献中的节点里对服务进行配置:服务不能自己运营,需要通过调用Context.startService()或Context.bindService()方法启动服务。这两个方法都可以启动Service,但是它

38、们的使用场合有所不同。使用startService()方法启用服务,调用者与服务之间没有关连,即使调用者退出了,服务仍然运营。使用bindService()方法启用服务,调用者与服务绑定在了一起,调用者一旦退出,服务也就终止,大有“不求同时生,必须同时死”的特点。假如打算采用Context.startService()方法启动服务,在服务未被创建时,系统会先调用服务的onCreate()方法,接着调用onStart()方法。假如调用startService()方法前服务已经被创建,多次调用startService()方法并不会导致多次创建服务,但会导致多次调用onStart()方法。采用sta

39、rtService()方法启动的服务,只能调用Context.stopService()方法结束服务,服务结束时会调用onDestroy()方法。假如打算采用Context.bindService()方法启动服务,在服务未被创建时,系统会先调用服务的onCreate()方法,接着调用onBind()方法。这个时候调用者和服务绑定在一起,调用者退出了,系统就会先调用服务的onUnbind()方法,接着调用onDestroy()方法。假如调用bindService()方法前服务已经被绑定,多次调用bindService()方法并不会导致多次创建服务及绑定(也就是说onCreate()和onBind

40、()方法并不会被多次调用)。假如调用者希望与正在绑定的服务解除绑定,可以调用unbindService()方法,调用该方法也会导致系统调用服务的onUnbind()-onDestroy()方法。服务常用生命周期回调方法如下: onCreate() 该方法在服务被创建时调用,该方法只会被调用一次,无论调用多少次startService()或bindService()方法,服务也只被创建一次。onDestroy()该方法在服务被终止时调用。与采用Context.startService()方法启动服务有关的生命周期方法onStart() 只有采用Context.startService()方法启动

41、服务时才会回调该方法。该方法在服务开始运营时被调用。多次调用startService()方法尽管不会多次创建服务,但onStart() 方法会被多次调用。与采用Context.bindService()方法启动服务有关的生命周期方法onBind()只有采用Context.bindService()方法启动服务时才会回调该方法。该方法在调用者与服务绑定期被调用,当调用者与服务已经绑定,多次调用Context.bindService()方法并不会导致该方法被多次调用。onUnbind()只有采用Context.bindService()方法启动服务时才会回调该方法。该方法在调用者与服务解除绑定期被

42、调用14、 注册广播有几种方式,这些方式有何优缺陷?请谈谈Android引入广播机制的用意。答:一方面写一个类要继承BroadcastReceiver第一种:在清单文献中声明,添加 action android:name=android.provider.Telephony.SMS_RECEIVED)第二种使用代码进行注册如:IntentFilter filter = new IntentFilter(android.provider.Telephony.SMS_RECEIVED);IncomingSMSReceiver receiver = new IncomgSMSReceiver();r

43、egisterReceiver(receiver.filter);两种注册类型的区别是:1)第一种不是常驻型广播,也就是说广播跟随程序的生命周期。2)第二种是常驻型,也就是说当应用程序关闭后,假如有信息广播来,程序也会被系统调用自动运营。15、 请解释下在单线程模型中Message、Handler、Message Queue、Looper之间的关系。答:简朴的说,Handler获取当前线程中的looper对象,looper用来从存放Message的MessageQueue中取出Message,再有Handler进行Message的分发和解决.Message Queue(消息队列):用来存放通过

44、Handler发布的消息,通常附属于某一个创建它的线程,可以通过Looper.myQueue()得到当前线程的消息队列Handler:可以发布或者解决一个消息或者操作一个Runnable,通过Handler发布消息,消息将只会发送到与它关联的消息队列,然也只能解决该消息队列中的消息Looper:是Handler和消息队列之间通讯桥梁,程序组件一方面通过Handler把消息传递给Looper,Looper把消息放入队列。Looper也把消息队列里的消息广播给所有的Handler:Handler接受到消息后调用handleMessage进行解决Message:消息的类型,在Handler类中的ha

45、ndleMessage方法中得到单个的消息进行解决在单线程模型下,为了线程通信问题,Android设计了一个Message Queue(消息队列), 线程间可以通过该Message Queue并结合Handler和Looper组件进行信息互换。下面将对它们进行分别介绍:1. Message Message消息,理解为线程间交流的信息,解决数据后台线程需要更新UI,则发送Message内含一些数据给UI线程。2. Handler Handler解决者,是Message的重要解决者,负责Message的发送,Message内容的执行解决。后台线程就是通过传进来的 Handler对象引用来sendM

46、essage(Message)。而使用Handler,需要implement 该类的 handleMessage(Message)方法,它是解决这些Message的操作内容,例如Update UI。通常需要子类化Handler来实现handleMessage方法。3. Message Queue Message Queue消息队列,用来存放通过Handler发布的消息,按照先进先出执行。 每个message queue都会有一个相应的Handler。Handler会向message queue通过两种方法发送消息:sendMessage或post。这两种消息都会插在message queue队

47、尾并按先进先出执行。但通过这两种方法发送的消息执行的方式略有不同:通过sendMessage发送的是一个message对象,会被 Handler的handleMessage()函数解决;而通过post方法发送的是一个runnable对象,则会自己执行。4. Looper Looper是每条线程里的Message Queue的管家。Android没有Global的Message Queue,而Android会自动替主线程(UI线程)建立Message Queue,但在子线程里并没有建立Message Queue。所以调用Looper.getMainLooper()得到的主线程的Looper不为NULL,但调用Looper.myLooper() 得到当前线程的Looper就有也许为NULL。对于子线程使用Looper,API Doc提供了对的的使用方法:这个Message机制的大约流程: 1. 在Looper.loop()方法运营开始后,循环地按照接受顺序取出Message Queue里面的非NULL的Message。 2. 一开始Message Queue里面

展开阅读全文
部分上传会员的收益排行 01、路***(¥15400+),02、曲****(¥15300+),
03、wei****016(¥13200+),04、大***流(¥12600+),
05、Fis****915(¥4200+),06、h****i(¥4100+),
07、Q**(¥3400+),08、自******点(¥2400+),
09、h*****x(¥1400+),10、c****e(¥1100+),
11、be*****ha(¥800+),12、13********8(¥800+)。
相似文档                                   自信AI助手自信AI助手
搜索标签

当前位置:首页 > 考试专区 > 其他

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服