handler之runnable通信

2024-05-09 07:08
文章标签 通信 handler runnable

本文主要是介绍handler之runnable通信,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

由于对android很多方便的知识都只是一个浅显的认识,在脑海中或许有的知识点只是一个印象,今天写这篇博客的目的,也希望是我给自己真正想投入到移动开发的一个起步,记下每天的一点一滴,做一个一个的Demo,来加深自己的理解。

如今是互联网移动开发的爆发期,促进了信息业的高速发展,在android方面要想在移动开发领域做好,我想作为我这样的一个程序员,不能不懂点通信,已经不是单机的时代了,当然今天就用我做的小demo,结合网上的参考,来讲述下android的handler之runnable通信,当然只是android应用中的线程间的通信。

 

android应用程序运行时,一个被称作UI线程的主线程被创建,此线程主要负责UI事件的相关处理,android基于UI事件的处理是基于单线程的模型。所以我们尽量只能在UI主线程中对这些UI元素进行操作,否则可能会报错,同样如果在UI主线程中去做一些耗时的操作,因为这将会影响后面UI事件的监听,所以同样会保ANR错误,ANR是什么,想必大家都知道,不知道可以去网上查,这里不做详解。所以在android中通常把一些运算较大的或者IO类操作放到子线程中去处理,来避免阻塞UI线程,那处理完之后如何与UI线程通信呢?以将返回来的数据或者命令标识用于更新UI界面呢?此时就要涉及到android的消息循环机制(Looper)与Handler进行处理。

Looper:每一个线程都可以产生一个Looper,用来管理线程的Message,Looper会建立一个MessageQueue这样的一个数据结构(即消息队列),用来存放message进行轮循处理message。

Handler:与Looper沟通的对象,可以push消息或者Runnable对象到MessageQueue中,也可以从MessageQueue中得到消息。

以上是一些基本概念的描述,下面贴上代码。

 

package com.example.handler;import android.os.Bundle;
import android.os.Handler;
import android.app.Activity;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.TextView;public class MainActivity extends Activity implements OnClickListener {/* 主UI线程相关view组件句柄 */private Button getSubID;private TextView mainThreadID, subThreadID;/* 涉及通信的桥接资源的引用句柄 */private long subID;// 子线程IDprivate Handler myHandler;// 用于通信的handler// 待looper的runnableprivate Runnable runnable;// 待looper的runnable的构造class myRunnable implements Runnable {@Overridepublic void run() {// TODO 自动生成的方法存根subThreadID.setText("此信息由子线程输出--> 子线程的ID : " + subID);}}// 操作handler的子线程的构造class MySubThread extends Thread {@Overridepublic void run() {// TODO 自动生成的方法存根subID = Thread.currentThread().getId();myHandler.post(runnable);}}@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.main);// init handlermyHandler = new Handler();// init runnablerunnable = new myRunnable();setupView();}private void setupView() {// TODO 自动生成的方法存根getSubID = (Button) findViewById(R.id.btn_get_sub_thread_id);mainThreadID = (TextView) findViewById(R.id.label_main_thread_id);subThreadID = (TextView) findViewById(R.id.label_sub_thread_id);mainThreadID.setText("main thread ID : "+ Thread.currentThread().getId());getSubID.setOnClickListener(this);}@Overridepublic void onClick(View view) {// TODO 自动生成的方法存根if (view == getSubID) {new MySubThread().start();}}}下面是布局文件:
<pre name="code" class="html"><?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical" ><TextViewandroid:id="@+id/label_main_thread_id"android:layout_width="wrap_content"android:layout_height="wrap_content"android:textAppearance="?android:attr/textAppearanceLarge" /><Buttonandroid:id="@+id/btn_get_sub_thread_id"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="get sub Thread ID-->" /><TextViewandroid:id="@+id/label_sub_thread_id"android:layout_width="wrap_content"android:layout_height="wrap_content"android:textAppearance="?android:attr/textAppearanceLarge" /></LinearLayout>


 

其基本的步骤如下:

在MainActivity.java中首先设置基本的界面,就不必详说了,然后就是初始化main thread的信使Handler,以及用于在主UI线程回调的runnable,起作用当然是用于显示子线程的ID,至于对已经构造好的Handler和Runnable类型的对象如何触发生效则是在setupView中,setupView首先去初始化一些UI组件的引用,然后为按钮绑定触发事件,当点击按钮时去触发启动子线程,这个子线的run方法已构造好,自然是写入子线程的ID,然后借助Handler把待looper的Runnable给push到主UI线程的消息循环队列中。至于其中的设计机制还是蛮值得细加品味的。


当然以上只是重点在讲Handler的post通信方式,如果我的理解有误,还望高手指教!





这篇关于handler之runnable通信的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/972724

相关文章

RabbitMQ工作模式中的RPC通信模式详解

《RabbitMQ工作模式中的RPC通信模式详解》在RabbitMQ中,RPC模式通过消息队列实现远程调用功能,这篇文章给大家介绍RabbitMQ工作模式之RPC通信模式,感兴趣的朋友一起看看吧... 目录RPC通信模式概述工作流程代码案例引入依赖常量类编写客户端代码编写服务端代码RPC通信模式概述在R

在Spring Boot中实现HTTPS加密通信及常见问题排查

《在SpringBoot中实现HTTPS加密通信及常见问题排查》HTTPS是HTTP的安全版本,通过SSL/TLS协议为通讯提供加密、身份验证和数据完整性保护,下面通过本文给大家介绍在SpringB... 目录一、HTTPS核心原理1.加密流程概述2.加密技术组合二、证书体系详解1、证书类型对比2. 证书获

Python模拟串口通信的示例详解

《Python模拟串口通信的示例详解》pySerial是Python中用于操作串口的第三方模块,它支持Windows、Linux、OSX、BSD等多个平台,下面我们就来看看Python如何使用pySe... 目录1.win 下载虚www.chinasem.cn拟串口2、确定串口号3、配置串口4、串口通信示例5

基于C#实现MQTT通信实战

《基于C#实现MQTT通信实战》MQTT消息队列遥测传输,在物联网领域应用的很广泛,它是基于Publish/Subscribe模式,具有简单易用,支持QoS,传输效率高的特点,下面我们就来看看C#实现... 目录1、连接主机2、订阅消息3、发布消息MQTT(Message Queueing Telemetr

Java中的runnable 和 callable 区别解析

《Java中的runnable和callable区别解析》Runnable接口用于定义不需要返回结果的任务,而Callable接口可以返回结果并抛出异常,通常与Future结合使用,Runnab... 目录1. Runnable接口1.1 Runnable的定义1.2 Runnable的特点1.3 使用Ru

Java中Runnable和Callable的区别和联系及使用场景

《Java中Runnable和Callable的区别和联系及使用场景》Java多线程有两个重要的接口,Runnable和Callable,分别提供一个run方法和call方法,二者是有较大差异的,本文... 目录一、Runnable使用场景二、Callable的使用场景三、关于Future和FutureTa

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

【STM32】SPI通信-软件与硬件读写SPI

SPI通信-软件与硬件读写SPI 软件SPI一、SPI通信协议1、SPI通信2、硬件电路3、移位示意图4、SPI时序基本单元(1)开始通信和结束通信(2)模式0---用的最多(3)模式1(4)模式2(5)模式3 5、SPI时序(1)写使能(2)指定地址写(3)指定地址读 二、W25Q64模块介绍1、W25Q64简介2、硬件电路3、W25Q64框图4、Flash操作注意事项软件SPI读写W2

vue2 组件通信

props + emits props:用于接收父组件传递给子组件的数据。可以定义期望从父组件接收的数据结构和类型。‘子组件不可更改该数据’emits:用于定义组件可以向父组件发出的事件。这允许父组件监听子组件的事件并作出响应。(比如数据更新) props检查属性 属性名类型描述默认值typeFunction指定 prop 应该是什么类型,如 String, Number, Boolean,

linux中使用rust语言在不同进程之间通信

第一种:使用mmap映射相同文件 fn main() {let pid = std::process::id();println!(