Handler机制

一、Handler的定义:

   Handler主要用于接收子线程发送过来的数据, 并用此数据配合主线程进行UI的更新。

   当应用程序启动时,Android首先会开启一个主线程 (UI线程),主线程主要为管理界面中的UI控件,进行事件的分发,比如,你要点击一个 Button控件,Android就会通过此Button的监听器分发事件到此Button上,以此来响应你的操作。如果此时是一个需要耗时长的操作,例如:联网读取数据,或者读取本地较大的一个文件的时候,就不能把这些操作放在主线程当中了,如果被放在主线程中的话,界面会出现假死现象,如果5秒钟还没有完成的话,会收到Android系统的一个错误提示“强制关闭”。这个时候就需要把这些耗时的操作,放在一个子线程当中了,因为子线程可能会涉及到UI的更新,当新线程中有涉及到操作UI的操作时,就会对主线程产生危险,因此,Android提供了Handler作为主线程和子线程的纽带。也就是说,更新UI只能在主线程当中进行更新,在子线程中操作是危险的。

   由于Handler是运行在主线程当中(UI线程中),它与子线程主要是通过Message对象来传递数据,这个时候,Handler就承担着接收子线程传过来的(子线程用sedMessage()方法传递)Message对象(里面包含数据),把这些消息放入主线程队列中,配合主线程进行更新UI。

   注意:Handler 对象初始化后,就默认与对它初始化的进程的消息队列绑定,因此可以利用Handler所包含的消息队列,制定一些操作的顺序。

 

二、Handler的主要作用

1. 传递Message,用于接收子线程发送过来的数据, 并用此数据配合主线程更新UI。

    在Android中,对于UI的操作通常需要放在主线程中进行操作。如果在子线程中有关于UI的操作,那么就需要把数据消息作为一个Message对象发送到消息队列中,然后,由Handler中的handlerMessge()方法处理传过来的数据信息,并操作UI。当然,Handler对象是在主线程中初始化的,它需要绑定在主线程的消息队列中。

    类sendMessage(Message msg)方法实现发送消息的操作。在初始化Handler对象时重写的handleMessage()方法是用来来接收Messgae并进行相关操作的。

2. 传递Runnable对象,用于通过Handler绑定的消息队列,安排不同操作的执行顺序。

    Handler对象在进行初始化的时候,会默认的自动绑定消息队列。利用类post方法,可以将Runnable对象发送到消息队列中,按照队列的机制按顺序执行不同的Runnable对象中的run方法。

三、Handler的一些特点

handler可以分发Message对象或Runnable对象到主线程中,每个Handler实例,都会被绑定到创建它的线程中(一般是位于主线程)。

      

Handler中分发消息的一些方法:

post(Runnable)

postAtTime(Runnable,long)

postDelayed(Runnable long)

sendEmptyMessage(int)

sendMessage(Message)

sendMessageAtTime(Message,long)

sendMessageDelayed(Message,long)

以上post类方法允许你排列一个Runnable对象到主线程队列当中;

sendMessage类方法,允许你安排一个带数据的Message对象到队列中。

注意:

   默认情况下,Handler接受的是当前线程下的消息循环实例(使用Handler(Looper looper)、Handler(Looper looper, Handler.Callback callback) 可以指定线程),同时一个消息队列可以被当前线程中的多个对象进行分发、处理(在UI线程中,系统已经有一个Activity来处理了,你可以再起若干个 Handler来处理)。在实例化Handler的时候,Looper可以是任意线程的,只要有Handler的指针,任何线程也都可以 sendMessage。Handler对于Message的处理不是并发的。一个Looper 只有处理完一条Message才会读取下一条,所以消息的处理是阻塞形式的(handleMessage()方法里不应该有耗时操作,可以将耗时操作放在 其他线程执行,操作完后发送Message(通过sendMessges方法),然后由handleMessage()更新UI)。

代码如下:

public class HandlerTestActivity extends Activity {
 private <span style="white-space:pre">	</span>TextView tv;
<span style="white-space:pre">		</span>private static final int UPDATE = 0;
<span style="white-space:pre">		</span>private Handler handler = new Handler() {
 @Override


        public<span style="white-space:pre">	</span>void handleMessage(Message msg) {


            //TODO 接收消息并且去更新UI线程上的控件内容


            if (msg.what == UPDATE) {


                //Bundle b = msg.getData();


                //tv.setText(b.getString("num"));


                tv.setText(String.valueOf(msg.obj));}
<span style="white-space:pre">		</span>super.handleMessage(msg);
 }


    };
<span style="white-space:pre">			</span>@Override


    public<span style="white-space:pre">	</span>void onCreate(Bundle savedInstanceState) {


        super.onCreate(savedInstanceState);


        setContentView(R.layout.main);


        tv= (TextView) findViewById(R.id.tv);
<span style="white-space:pre">		</span>new<span style="white-space:pre">	</span> Thread() {
@Override


            public<span style="white-space:pre">		</span>void  run() {


                //TODO 子线程中通过handler发送消息给handler接收,由handler去更新TextView的值


                try{     <span style="white-space:pre">	</span>for(int i = <span style="font-family: 微软雅黑, Verdana, sans-serif, 宋体;">0;</span>i <</code> 100;i++) {
<span style="white-space:pre">				</span>Thread.sleep(500);


                       Message msg = new Message();


                        msg.what= UPDATE;


                        //Bundle b = new Bundle();


                        //b.putString("num", "更新后的值:" + i);


                        //msg.setData(b);


                        msg.obj= "更新后的值:" + i;


                        handler.sendMessage(msg);


                    }


                }catch (InterruptedException e) {
<span style="white-space:pre">				</span>  e.printStackTrace();


                }


            }


        }.start();


    }

 


}


内容概要:本文详细探讨了基于MATLAB/SIMULINK的多载波无线通信系统仿真及性能分析,重点研究了以OFDM为代表的多载波技术。文章首先介绍了OFDM的基本原理和系统组成,随后通过仿真平台分析了不同调制方式的抗干扰性能、信道估计算法对系统性能的影响以及同步技术的实现与分析。文中提供了详细的MATLAB代码实现,涵盖OFDM系统的基本仿真、信道估计算法比较、同步算法实现和不同调制方式的性能比较。此外,还讨论了信道特征、OFDM关键技术、信道估计、同步技术和系统级仿真架构,并提出了未来的改进方向,如深度学习增强、混合波形设计和硬件加速方案。; 适合人群:具备无线通信基础知识,尤其是对OFDM技术有一定了解的研究人员和技术人员;从事无线通信系统设计与开发的工程师;高校通信工程专业的高年级本科生和研究生。; 使用场景及目标:①理解OFDM系统的工作原理及其在多径信道环境下的性能表现;②掌握MATLAB/SIMULINK在无线通信系统仿真中的应用;③评估不同调制方式、信道估计算法和同步算法的优劣;④为实际OFDM系统的设计和优化提供理论依据和技术支持。; 其他说明:本文不仅提供了详细的理论分析,还附带了大量的MATLAB代码示例,便于读者动手实践。建议读者在学习过程中结合代码进行调试和实验,以加深对OFDM技术的理解。此外,文中还涉及了一些最新的研究方向和技术趋势,如AI增强和毫米波通信,为读者提供了更广阔的视野。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值