当前位置: 首页 > wzjs >正文

如何制作自己的网站链接视频公司企业员工培训

如何制作自己的网站链接视频,公司企业员工培训,网页设计与制作第二版电子版,课程网站课程资源建设Handler消息机制源码分析 一、概述 Handler消息机制是Android系统中最重要的特性之一,它主要用于解决Android单线程模型中的线程间通信问题。本文将深入分析Handler消息机制的源码实现,帮助你理解其工作原理。 二、基础知识 2.1 Handler消息机制的核…

Handler消息机制源码分析

一、概述

Handler消息机制是Android系统中最重要的特性之一,它主要用于解决Android单线程模型中的线程间通信问题。本文将深入分析Handler消息机制的源码实现,帮助你理解其工作原理。

二、基础知识

2.1 Handler消息机制的核心类

  • Handler:消息处理者,负责发送和处理消息
  • Message:消息对象,包含要传递的信息
  • MessageQueue:消息队列,用于存储消息
  • Looper:消息循环器,不断从MessageQueue中取出消息并交给Handler处理

2.2 基本工作流程

  1. Handler发送消息到MessageQueue
  2. Looper不断从MessageQueue中取出消息
  3. Handler处理Looper分发来的消息

三、源码分析

3.1 Handler的创建

class MainActivity : AppCompatActivity() {private val handler = object : Handler(Looper.getMainLooper()) {override fun handleMessage(msg: Message) {when (msg.what) {MSG_UPDATE_UI -> updateUI()}}}
}

源码中Handler的构造过程:

public Handler(@Nullable Looper looper) {this(looper, null, false);
}public Handler(@Nullable Looper looper, @Nullable Callback callback, boolean async) {mLooper = looper;mQueue = looper.mQueue;mCallback = callback;mAsynchronous = async;
}

3.2 消息的发送过程

// 发送消息的几种方式
handler.sendMessage(msg)
handler.sendEmptyMessage(what)
handler.sendMessageDelayed(msg, delayMillis)
handler.post(runnable)

源码分析:

public final boolean sendMessage(@NonNull Message msg) {return sendMessageDelayed(msg, 0);
}public final boolean sendMessageDelayed(@NonNull Message msg, long delayMillis) {if (delayMillis < 0) {delayMillis = 0;}return sendMessageAtTime(msg, SystemClock.uptimeMillis() + delayMillis);
}public boolean sendMessageAtTime(@NonNull Message msg, long uptimeMillis) {MessageQueue queue = mQueue;return enqueueMessage(queue, msg, uptimeMillis);
}private boolean enqueueMessage(@NonNull MessageQueue queue, @NonNull Message msg,long uptimeMillis) {msg.target = this;msg.workSourceUid = ThreadLocalWorkSource.getUid();if (mAsynchronous) {msg.setAsynchronous(true);}return queue.enqueueMessage(msg, uptimeMillis);
}

3.3 MessageQueue的工作原理

MessageQueue是一个优先级队列,按照消息的执行时间排序。

boolean enqueueMessage(Message msg, long when) {// 省略参数检查代码synchronized (this) {msg.markInUse();msg.when = when;Message p = mMessages;boolean needWake;// 根据时间顺序将消息插入队列if (p == null || when == 0 || when < p.when) {msg.next = p;mMessages = msg;needWake = mBlocked;} else {needWake = mBlocked && p.target == null && msg.isAsynchronous();Message prev;for (;;) {prev = p;p = p.next;if (p == null || when < p.when) {break;}}msg.next = p;prev.next = msg;}if (needWake) {nativeWake(mPtr);}}return true;
}

3.4 Looper的消息循环

Looper负责从MessageQueue中取出消息并分发给Handler处理。

public static void loop() {final Looper me = myLooper();final MessageQueue queue = me.mQueue;for (;;) {Message msg = queue.next(); // 可能阻塞if (msg == null) {return;}try {msg.target.dispatchMessage(msg);} finally {msg.recycleUnchecked();}}
}

四、实战案例

4.1 异步任务处理

class ImageLoadActivity : AppCompatActivity() {private val handler = object : Handler(Looper.getMainLooper()) {override fun handleMessage(msg: Message) {when (msg.what) {MSG_LOAD_SUCCESS -> {val bitmap = msg.obj as BitmapimageView.setImageBitmap(bitmap)}MSG_LOAD_FAILED -> {Toast.makeText(this@ImageLoadActivity, "加载失败", Toast.LENGTH_SHORT).show()}}}}private fun loadImage() {Thread {try {val bitmap = loadImageFromNetwork()val msg = Message.obtain()msg.what = MSG_LOAD_SUCCESSmsg.obj = bitmaphandler.sendMessage(msg)} catch (e: Exception) {handler.sendEmptyMessage(MSG_LOAD_FAILED)}}.start()}companion object {const val MSG_LOAD_SUCCESS = 1const val MSG_LOAD_FAILED = 2}
}

4.2 延时任务处理

class CountDownActivity : AppCompatActivity() {private var countDown = 60private val handler = object : Handler(Looper.getMainLooper()) {override fun handleMessage(msg: Message) {when (msg.what) {MSG_COUNT_DOWN -> {countDown--tvCountDown.text = "${countDown}s"if (countDown > 0) {sendEmptyMessageDelayed(MSG_COUNT_DOWN, 1000)}}}}}override fun onDestroy() {super.onDestroy()handler.removeCallbacksAndMessages(null)}companion object {const val MSG_COUNT_DOWN = 1}
}

五、调试技巧

5.1 使用Looper.getMainLooper().setMessageLogging()跟踪消息

Looper.getMainLooper().setMessageLogging { log ->Log.d("MessageLogging", log)
}

5.2 使用systrace工具分析消息处理耗时

TraceCompat.beginSection("handleMessage")
try {// 处理消息
} finally {TraceCompat.endSection()
}

六、性能优化

6.1 避免内存泄漏

  • 使用静态内部类+弱引用
  • Activity销毁时移除消息
  • 使用LifecycleOwner管理Handler生命周期
class SafeHandler(lifecycleOwner: LifecycleOwner, private val callback: Handler.Callback) : Handler(Looper.getMainLooper()) {private val lifecycleRef = WeakReference(lifecycleOwner)init {lifecycleOwner.lifecycle.addObserver(object : DefaultLifecycleObserver {override fun onDestroy(owner: LifecycleOwner) {removeCallbacksAndMessages(null)}})}override fun handleMessage(msg: Message) {lifecycleRef.get()?.let { lifecycle ->if (lifecycle.currentState.isAtLeast(Lifecycle.State.CREATED)) {callback.handleMessage(msg)}}}
}

6.2 消息复用

使用Message.obtain()而不是new Message()

val msg = Message.obtain()
try {msg.what = MSG_TYPEmsg.obj = datahandler.sendMessage(msg)
} catch (e: Exception) {msg.recycle()
}

七、常见面试题

7.1 Handler实现原理?

答:Handler的实现主要基于消息队列模型,包含四个核心组件:

  1. Handler:消息处理者,负责发送和处理消息
  2. Message:消息对象,存储消息的内容和元数据
  3. MessageQueue:消息队列,按时间顺序存储消息
  4. Looper:消息循环器,不断从队列中取出消息并分发给Handler

工作流程:

  1. Handler发送消息,消息进入MessageQueue
  2. Looper不断循环从MessageQueue中取出消息
  3. 消息分发给对应的Handler处理

7.2 Handler引起的内存泄漏原因及解决方案?

答:
原因:

  • Handler作为内部类持有外部Activity的引用
  • 发送延迟消息后Activity销毁,而消息队列中的Message持有Handler引用,Handler又持有Activity引用

解决方案:

  1. 使用静态内部类+弱引用
  2. Activity销毁时清空消息队列
  3. 使用LifecycleOwner管理Handler生命周期

7.3 Handler线程切换原理?

答:

  1. 每个线程可以通过Looper.prepare()创建Looper对象
  2. Looper对象包含一个MessageQueue
  3. Handler在构造时关联了Looper对象
  4. 消息会被发送到Looper关联的MessageQueue
  5. Looper所在线程通过loop()方法不断取出消息并处理

因此,Handler发送的消息在哪个线程被处理,取决于Handler构造时传入的Looper对象所属的线程。

八、源码分析小结

通过分析Handler消息机制的源码,我们了解到:

  1. Handler消息机制是一个生产者-消费者模型
  2. MessageQueue通过单链表实现优先级队列
  3. Looper通过死循环不断处理消息,但不会导致ANR
  4. 消息处理过程是同步的,保证了线程安全
  5. 系统通过ThreadLocal维护Looper,保证线程隔离

掌握Handler消息机制的原理,对于理解Android系统的消息驱动模型和异步编程具有重要意义。在实际开发中,合理使用Handler可以优雅地解决线程间通信问题。

九、参考资源

  1. Android源码:Handler.java
  2. Android开发者文档:Handler API Guide
  3. Android源码分析:Looper.java

本文通过深入分析Handler消息机制的源码实现,结合实际案例和面试题,帮助你全面理解Android消息机制的工作原理。在实际开发中,建议结合本文提供的最佳实践,合理使用Handler,避免常见问题。如果你对Handler机制还有任何疑问,欢迎在评论区留言交流。

http://www.dtcms.com/wzjs/451074.html

相关文章:

  • 国外社交网站做的比较好的是关键词seo排名优化如何
  • 做水果苹果大的网站网站排名优化公司
  • 响应式网页设计pptseo排名工具外包
  • 做购物网站学什么技术网站开发需要的技术
  • 三网合一网站建设合同无锡seo网站排名
  • 用wordpress做网站页面显示404百度站长收录
  • 怎么给网站做访问量整合营销的特点有哪些
  • 建网站选哪个域名查询网址
  • 在网站做推广要钱吗网络推广软文怎么写
  • 哪有专做注册小网站的网站优化外包费用
  • 一般ps做网站大小多少女排联赛最新排行榜
  • 即墨市网站建设百度做广告怎么收费
  • 代发广告平台关键词点击优化工具
  • 华艺网站开发pc网站优化排名软件
  • 做平面有什么好的网站一键优化表格
  • 做蛋糕网站策划书赵阳竞价培训
  • 高效省心的app定制开发平台网站优化排名软件哪些最好
  • 网站开发平台 运行平台策划推广方案
  • 北京网站开发月薪关键词推广seo怎么优化
  • 如何做b2b网站推广免费企业网站建设流程
  • 腾讯云主机做网站seo基础优化包括哪些内容
  • 洛阳网站设计哪家便宜宣传软文范例
  • 专门做茶叶的网站网站快速有排名
  • 网站制作价格中国网站排名网
  • 网站建设日期市场营销主要学什么
  • b2b典型网站集合竞价口诀背熟6句
  • 如何设计商务网站百度免费推广怎么做
  • 用ps做的网站怎么发布手机网站建设平台
  • 快速搭建论坛优化系统的软件
  • 网站域名的选择seo如何建立优化网站