实现定时器有很多种方式,在这里我简单的介绍几种方式(1)使用Handler + Runnable的方式[java] view plain copy
在CODE上查看代码片派生到我的代码片Handler handler = new Handler();  Runnable runnable = new Runnable() {  @Override  public void run() {  //你要做的事  //......  System.out.println(Thread.currentThread().getName());  handler.postDelayed(runnable, 1000);  }  };  然后调用handler.post(runnable);就能启动定时器,这里是每隔1s打印线程名字,从打印中我们可以知道,他并没有另开线程,而是运行在UI线程当中,当你要取消定时器的时候,只需要调用handler.removeCallbacks(runnable)就可以了。上面中有一个问题,有时候你会发现removeCallbacks有时候会失效,不能从消息队列中移除,看下面的demo

图:两个按钮,一个将Runnable加到消息队列中,一个将Runnable从消息队列中移除。该Runnable每1秒钟打印一次日志。[java] view plain copy
在CODE上查看代码片派生到我的代码片<span style="font-family:Courier New;">package com.example.demoactivity;  import android.app.Activity;  import android.os.Bundle;  import android.os.Handler;  import android.view.View;  import android.view.View.OnClickListener;  import android.widget.Button;  public class TimerActivity extends Activity{  Handler handler = new Handler();  Runnable runnable = new Runnable() {  @Override  public void run() {  System.out.println("update...");  handler.postDelayed(runnable, 1000);  }  };  @Override  protected void onCreate(Bundle savedInstanceState) {  super.onCreate(savedInstanceState);  setContentView(R.layout.timer);  Button mButtonStart = (Button) findViewById(R.id.button1);  Button mButtonStop = (Button) findViewById(R.id.button2);  mButtonStart.setOnClickListener(new OnClickListener() {  @Override  public void onClick(View v) {  handler.post(runnable);  }  });  mButtonStop.setOnClickListener(new OnClickListener() {  @Override  public void onClick(View v) {  handler.removeCallbacks(runnable);  }  });  }  }</span><span style="font-family: Georgia, 'Times new roman', Times, san-serif;">  </span>  结果:
(1)start –>  输出 –> stop–> 停止输出
(2)start –> 输出 –>  Background –> Front –> stop->继续输出当Activity进入后台运行后再转入前台运行,removeCallbacks无法将updateThread从message queue中移除。
这是为什么呢?
在Activity由前台转后台过程中,线程是一直在运行的,但是当Activity转入前台时会重新定义Runnable runnable;也就是说此时从message queue移除的runnable与原先加入message queue中的runnable并非是同一个对象。如果把runnable定义为静态的则removeCallbacks不会失效,对于静态变量在内存中只有一个拷贝(节省内存),JVM只为静态分配一次内存,在加载类的过程中完成静态变量的内存分配,我们做如下修改就能解决上面的这个问题

    static Handler handler = new Handler();  static Runnable runnable = new Runnable() {  @Override  public void run() {  System.out.println("update...");  handler.postDelayed(runnable, 1000);  }  };  (2)使用Timer的方式[java] view plain copy
在CODE上查看代码片派生到我的代码片Timer timer = new Timer();  timer.schedule(new TimerTask() {  @Override  public void run() {  System.out.println("update....");  }  }, 0, 1000);  上面的每一秒打印语句,run方法是运行在子线程,不能直接在里面更新UI操作,这里需要注意下,取消的话调用timer.cancel()就能移除任务了(3)采用Handle与线程的sleep(long )方法1.定义一个Handler类,用于处理接受到的Message[java] view plain copy
在CODE上查看代码片派生到我的代码片Handler handler = new Handler() {  public void handleMessage(Message msg) {  super.handleMessage(msg);  System.out.println("update...");  }  }  2.新建一个实现Runnable接口的线程类,用一个boolean 来控制线程开始和结束  boolean isLive = true如下:[java] view plain copy
在CODE上查看代码片派生到我的代码片public class MyThread implements Runnable {  @Override  public void run() {  while (isLive) {  try {  Thread.sleep(1000);// 线程暂停1秒,单位毫秒  Message message = new Message();  message.what = 1;  handler.sendMessage(message);// 发送消息  } catch (InterruptedException e) {  e.printStackTrace();  }  }  }  }  3.在需要启动线程的地方加入下面语句[java] view plain copy
在CODE上查看代码片派生到我的代码片new Thread(new MyThread()).start();  4.取消的话将isLive设置为false就行了今天主要介绍这三种方法,写的不好的地方希望大家指出,谢谢!

转载于:https://www.cnblogs.com/yaowen/p/5667530.html

Android 定时器实现的几种方式和removeCallbacks失效问题详解相关推荐

  1. Android之定时器实现的几种方式和removeCallbacks失效问题详解

    转载:http://blog.csdn.net/xiaanming/article/details/9011193 实现定时器有很多种方式,在这里我简单的介绍几种方式 实现定时器有很多种方式,在这里我 ...

  2. Android定时器死循环问题,Android定时器实现的几种方式整理及removeCallbacks失效问题解决...

    实现定时器有很多种方式,在这里我简单的介绍几种方式 (1)使用Handler + Runnable的方式 Handler handler = new Handler(); Runnable runna ...

  3. 进程间通信有哪几种方式?进程间通信的方法详解

    进程间通信有哪几种方式?不同进程之间是会进行相互传播或交换信息的,很多伙伴都很好奇,各进程之间是通过什么介质进行通信的呢?今天小编就给大家科普下进程间通信的方法. 前言: 进程间通信(IPC,Inte ...

  4. android开启gps功能,android 打开GPS的几种方式

    1.在讨论打开gps的之前先看下如何检测gps的开关情况: 方式一: boolean gpsEnabled = locationManager.isProviderEnabled(LocationMa ...

  5. android ui 最新教程,Android更新UI的五种方式,androidui五种

    Android更新UI的五种方式,androidui五种handler.post activity.runOnUiThread view.post handler+Thread AsyncTask 例 ...

  6. android注册广播两种方式,Android 注册广播的两种方式对比

    Android 注册广播的两种方式对比 1.常驻型广播 常驻型广播,当你的应用程序关闭了,如果有广播信息来,你写的广播接收器同样的能接受到, 他的注册方式就是在你的应用程序中的AndroidManif ...

  7. android 图片方法,分享实现Android图片选择的两种方式

    Android选择图片的两种方式: 第一种:单张选取 通过隐式启动activity,跳转到相册选择一张返回结果 关键代码如下: 发送请求: private static final int PICTU ...

  8. android使用其他应用打开方式,Android 启动activity的4种方式及打开其他应用的activity的坑...

    Android启动的四种方式分别为standard,singleTop,singleTask,singleInstence. standard是最常见的activity启动方式,也是默认的启动的方式. ...

  9. android视频播放的方法,Android实现视频播放的几种方式

    Android实现视频播放的3种方式 Android提供了常见的视频编码,解码机制,使用Android自带的MediaPlayer,MediaController等类可以很方便的实现视频播放的功能.支 ...

最新文章

  1. C++ Primer 5th笔记(7)chapter7 类:字面值常量类
  2. LUOGU P4587 [FJOI2016]神秘数(主席树)
  3. J storm战队成员_DOTA2J.Storm战队介绍-DOTA2ESL孟买站预选赛J.Storm战队介绍_牛游戏网攻略...
  4. 多线程队列的算法优化
  5. xss-lab靶场通关writeup(1~6.......在更新)
  6. 嵩天python123测试6_神华化工股票
  7. left join 和inner join关联查询区别
  8. 基于机器视觉的玻璃Mark点字符识别
  9. PyTorch 入坑七:模块与nn.Module学习
  10. T-SQL查询进阶—理解SQL Server中的锁
  11. 股票分时数据HTML,股票历史分时数据
  12. 大专读者被裁,但他却拒绝了42k的Offer?| 一名爬虫工程师自述
  13. 苹果企业开发者账号证书申请(保姆级)
  14. mysql 列连接_计数mysql中的连接列
  15. 1ppi等于多少dpi_Android开发之显示篇(弄懂ppi、dpi、pt、px、dp、dip、sp之间的关系只需这一篇)...
  16. win10亮度_Win10系统运行游戏或大型软件的优化设置教程
  17. 快手安全 X 墨菲安全 | 软件供应链安全解决方案完整分享
  18. MATLAB 太阳系九大行星运行(天文物理)天体仿真(一)
  19. python导入pyx文件_初学Python,只会写简单的代码。手头有份Python代码,但是调用C模块生成的.pxd和.pyx文件,运行过程总报错,希望大神指点,调试前该做哪些工作呢?...
  20. 没想到吧!没签劳动合同,能不能拿到双倍工资赔偿?今天统一回复~【文末送书】...

热门文章

  1. 【机器视觉】 dev_set_preferences算子
  2. 【MFC】MFC对话框类
  3. aspx隐藏前台控件div_javascript总结--div
  4. html5 video如何添加进度条_教你制作独一无二的进度条视频效果
  5. 本地缓存需要高时效性怎么办_太难为我了,为了这份P7岗offer,我承受了7轮面试...
  6. 51nod 1785 数据流中的算法 (方差计算公式)
  7. 超全流程-idea对springboot+ssm的部署实现增删改查
  8. java通过对.class文件字节码加密,不被轻易反编译出源代码,分析及其实现。
  9. 我的世界1.13的服务器网站,我的世界1.13纯净版
  10. mysql导出html工具类,如何在codeigniter中将csv文件导入MYSQL,其中包含html标签