Android用5种方式实现自定义计时器, 哪种才是你的菜?
Chronometer和CountDownTimer计时器
github传送门
目录
- 效果图
- 前言
- Timer + TimerTask + Handler
- Timer + TimerTask
- Handler
- Thread + Handler
- Handler + Runnable
- 最后
效果图
看下效果图, 这是五种不同的方式演示计时器. 当然不看源码是看不出差别的.
前言
这次的文章不知道能不能帮助大家, 但是对我自己的帮助还是蛮大的, 才知道自己原来用的方法不是最优而且也不是最简. 然后我之前有一篇文章是用官方控件和类实现的, 有兴趣可以看一下Chronometer和CountDownTimer计时器.
Timer + TimerTask + Handler
在TimerTask实例的run方法中用Handler实例发送消息, 用Timer实例启动计时器, 从0ms开始, 间隔1000ms.
case R.id.cv_start1: if (mTimer1 == null && mTask1 == null) { mTimer1 = new Timer(); mTask1 = new TimerTask() { @Override public void run() { Message message = mHandler.obtainMessage(1); mHandler.sendMessage(message); } }; mTimer1.schedule(mTask1, 0, 1000); } break; case R.id.cv_stop1: if (mTimer1 != null) { mTimer1.cancel(); mTimer1 = null; } if (mTask1 != null) { mTask1.cancel(); mTask1 = null; } break;
Timer + TimerTask
比起第一种, 这种更Java, 但是可以少一个Handler实例.
if (mTimer2 == null && mTask2 == null) { mTimer2 = new Timer(); mTask2 = new TimerTask() { @Override public void run() { runOnUiThread(new Runnable() { @Override public void run() { mTvTime2.setText(getTime()); } }); } }; mTimer2.schedule(mTask2, 0, 1000); }
Handler
这种方法就直接告别Timer和TimerTask了, 通过Handler的发消息延迟sendMessageDelayed以及不同的消息内容(就是what值)解决问题.
case R.id.cv_start3: { Message message = mHandler.obtainMessage(2); mHandler.sendMessage(message); } break; case R.id.cv_stop3: { Message message = mHandler.obtainMessage(3); mHandler.sendMessage(message); }
case 2: { mTvTime3.setText(getTime()); this.removeMessages(2); Message message = this.obtainMessage(2); this.sendMessageDelayed(message, 1000); } break; case 3: this.removeMessages(2); break;
Thread + Handler
老朋友Thread + Handler, 原来经常这么写, 现在不了(手动滑稽).
/** * 启动线程 */ private void startThread() { if (mThread == null) { mThread = new MyThread(); mThread.start(); } } /** * 停止线程 */ private void stopThread() { if (mThread != null) { mThread.stop = true; mThread = null; Message message = mHandler.obtainMessage(5); mHandler.sendMessage(message); } }
Handler + Runnable
最后一种我目前最喜欢. 你连what值都无需处理, 直接postDelayed设置时延, 然后交给实现Runnable接口的实例的run方法来做.
case R.id.cv_start5: { if (mRunnable == null) { mRunnable = new MyRunnable(); mHandler.postDelayed(mRunnable, 0); } } break; case R.id.cv_stop5: { mHandler.removeCallbacks(mRunnable); mRunnable = null; } break;
private class MyRunnable implements Runnable { @Override public void run() { mTvTime5.setText(getTime()); mHandler.postDelayed(this, 1000); } }
最后
总之一点, 用第三种Handler和第五种Handler + Runnable肯定比其它的消耗少得多, 所以很推荐. 或者你还有更棒的方法可以评论区告诉我下. 喜欢记得点赞, 暗中关注我也是可以的哦~

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
TabLayout的自定义
TabLayout的自定义,主要是通过setCustomView方法来添加自定义布局实现。 自定义TabLayout的实现主要包含以下几个步骤 ●创建自定义布局(这里我加了一个动画控件,可以替换成其他控件) <?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:app="http://schemas.android.com/apk/res-auto" android:layout_width="match_parent" android:layout_height="match_parent"> <LinearLayout android:layout_width="wrap_content" android:orientation="horizontal" android:gravity="center_vertical" android:layout_centerInP...
- 下一篇
fishhook源码分析
最早了解到fishhook是看了下面两篇文章之后,顿时让我觉得这是一个非常好的东西。总共210行代码,收获了1500+个star,神作啊。 iOS Lazy Binding,使用fishhook拦截NSSetUncaughtExceptionHandler函数解决NSUncaughtExceptionHandler被修改的问题。 聊聊苹果的Bug - iOS 10 nano_free Crash,通过fishhook替换malloc相关的函数尝试解决crash。 OC的runtime非常强大,可以玩很多黑魔法。而操作系统也会提供一些基础设施,比如Solaris/Mac DTrace和Linux systemtap,通过编写脚本分析各种系统调用的情况。相比之下,C语言没有runtime,也玩不出什么花来。不过fishhook提供了一种很好
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS7设置SWAP分区,小内存服务器的救世主
- Mario游戏-低调大师作品
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- 2048小游戏-低调大师作品
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- MySQL8.0.19开启GTID主从同步CentOS8
- CentOS8安装Docker,最新的服务器搭配容器使用
- CentOS8安装MyCat,轻松搞定数据库的读写分离、垂直分库、水平分库
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- CentOS7,CentOS8安装Elasticsearch6.8.6