Android定时器实现定时执行、重复执行、定时重复执行、定次数执行的多种方式
时间:2022-07-28
本文章向大家介绍Android定时器实现定时执行、重复执行、定时重复执行、定次数执行的多种方式,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
作用:
1、定时执行某种功能
2、重复执行、定时重复执行、定次数执行某种功能
类别:
1、Thread(new Runnable)
2、Thread()
3、Timer
4、Handler
·····
代码如下:
1、布局
<?xml version="1.0" encoding="utf-8"?
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="match_parent"
<Button
android:id="@+id/show_time"
android:text="请选择一种启动方式"
android:textSize="30dp"
android:layout_width="match_parent"
android:layout_height="100dp" /
<Button
android:id="@+id/timer_1"
android:textAllCaps="false"
android:text="定时方式1(Thread(new Runnable))"
android:layout_width="match_parent"
android:layout_height="wrap_content" /
<Button
android:id="@+id/timer_2"
android:text="定时方式2(Thread()) "
android:textAllCaps="false"
android:layout_width="match_parent"
android:layout_height="wrap_content" /
<Button
android:id="@+id/timer_3"
android:text="定时方式3(Timer) "
android:textAllCaps="false"
android:layout_width="match_parent"
android:layout_height="wrap_content" /
<Button
android:id="@+id/timer_4"
android:text="定时方式4(Handler) "
android:textAllCaps="false"
android:layout_width="match_parent"
android:layout_height="wrap_content" /
<Button
android:id="@+id/clear"
android:text="计时器清零 "
android:layout_width="match_parent"
android:layout_height="wrap_content" /
<TextView
android:layout_margin="10dp"
android:text="方式3停止方式不同(因为Timer一旦被cancel之后就废了,只有重新构造一个)n停止:1、开启3 2、点击停止 3、再点击方式3"
android:textAllCaps="false"
android:layout_width="match_parent"
android:layout_height="wrap_content" /
</LinearLayout
2、实现定时功能
package com.example.leixiansheng.mytimers;
import android.os.Handler;
import android.os.Message;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import java.util.Timer;
import java.util.TimerTask;
public class MainActivity extends AppCompatActivity implements View.OnClickListener {
private Button timer_1, timer_2, timer_3, timer_4,clear, showTime;
private Timer timer;
private TimerTask timerTask;
private int num = 0; //计数值
private boolean flog = true; //是否停止计时
private Handler handler = new Handler() {
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
showTime.setText("点击我停止计时: " + msg.what);
}
};
//handler 方式定时循环
private Handler handlerTimer = new Handler() {
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
if (flog) {
handlerTimer.sendEmptyMessageDelayed(num++, 1000);
}
showTime.setText("点击我停止计时: " + msg.what);
if(flog == false) {
flog = true;
}
}
};
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
timer_1 = (Button) findViewById(R.id.timer_1);
timer_2 = (Button) findViewById(R.id.timer_2);
timer_3 = (Button) findViewById(R.id.timer_3);
timer_4 = (Button) findViewById(R.id.timer_4);
clear = (Button) findViewById(R.id.clear);
showTime = (Button) findViewById(R.id.show_time);
timer_1.setOnClickListener(this);
timer_2.setOnClickListener(this);
timer_3.setOnClickListener(this);
timer_4.setOnClickListener(this);
clear.setOnClickListener(this);
showTime.setOnClickListener(this);
}
@Override
public void onClick(View view) {
switch (view.getId()) {
case R.id.timer_1:
method_1();
break;
case R.id.timer_2:
method_2();
break;
case R.id.timer_3:
method_3();
break;
case R.id.timer_4:
method_4();
break;
case R.id.clear:
num = 0;
showTime.setText("请选择一种启动方式");
break;
case R.id.show_time:
flog = false;
break;
}
}
private void method_4() {
new Thread() {
@Override
public void run() {
super.run();
handlerTimer.sendEmptyMessage(num++);
}
}.start();
}
private void method_3() {
//Timer一旦被cancel之后就废了,只有重新构造一个。
if (flog == true) {
timer = new Timer();
timerTask = new TimerTask() {
@Override
public void run() {
handler.sendEmptyMessage(num++);
}
};
/**
* 第一个参数:任务
* 第二个参数:初始启动等待时间
* 第三个参数:时间间隔
*/
timer.schedule(timerTask, 0, 1000);
} else {
timer.cancel();
// 一定设置为null,否则定时器不会被回收
timer = null;
flog = true;
}
//Timer 暂停重启有问题(待改进)
//Timer一旦被cancel之后就废了,只有重新构造一个。
// if (flog == true) {
// timerTask = new TimerTask() {
// @Override
// public void run() {
// handler.sendEmptyMessage(num++);
// }
// };
// /**
// * 第一个参数:任务
// * 第二个参数:初始启动等待时间
// * 第三个参数:时间间隔
// */
// timer.schedule(timerTask, 0, 1000);
// } else {
// timer.cancel();
// flog = true;
// }
}
private void method_2() {
//new Thread().start();
new Thread() {
@Override
public void run() {
super.run();
while (flog) {
handler.sendEmptyMessage(num++);
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}.start();
flog = true;
}
private void method_1() {
// new Thread(new Runnable).start();
new Thread(new Runnable() {
@Override
public void run() {
while (flog) {
handler.sendEmptyMessage(num++);
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}).start();
flog = true;
}
}
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对ZaLou.Cn的支持。如果你想了解更多相关内容请查看下面相关链接
- JQuery实现仿sina新浪微博新鲜事滚动
- 简单的jquery拖曵原理js特效实例
- 使用MiniProfiler调试ASP.NET MVC网站性能
- 大金主撑腰 4声母Mynt.com竟36万元结拍
- ASP.NET MVC4 Web API 堆栈将添加指定消息处理功能
- 页面copyright部分始终居于页面底部
- Hammock for REST
- 网页超过一屏时自动浮动在网页最上方的图层特效
- 关于gcc、glibc和binutils模块之间的关系
- 贝叶斯过滤算法
- 強大的jQuery Chart组件-Highcharts
- vue2.0 配置 选项 属性 方法 事件 ——速查
- 亲密接触IIS 8和Web Deploy 3.0
- vue2.0 组件通信
- java教程
- Java快速入门
- Java 开发环境配置
- Java基本语法
- Java 对象和类
- Java 基本数据类型
- Java 变量类型
- Java 修饰符
- Java 运算符
- Java 循环结构
- Java 分支结构
- Java Number类
- Java Character类
- Java String类
- Java StringBuffer和StringBuilder类
- Java 数组
- Java 日期时间
- Java 正则表达式
- Java 方法
- Java 流(Stream)、文件(File)和IO
- Java 异常处理
- Java 继承
- Java 重写(Override)与重载(Overload)
- Java 多态
- Java 抽象类
- Java 封装
- Java 接口
- Java 包(package)
- Java 数据结构
- Java 集合框架
- Java 泛型
- Java 序列化
- Java 网络编程
- Java 发送邮件
- Java 多线程编程
- Java Applet基础
- Java 文档注释
- Skywalking Php注册不上问题排查
- 接口403问题没这么容易解决
- 码云 Pages 搭建
- Meteva笔记:加载GRIB 2要素场
- crontab 指令笔记
- Shell 脚本实现串口操作
- 【CSS】714- 你所不知道的 CSS 负值技巧与细节
- SRC挖掘利器—溯光开源插件化渗透测试框架
- 【React】717- 从零实现 React-Redux
- 【Vue.js】Vue.js介绍及MVVM模式
- 【Vue.js】Vue.js基本语法
- 【JS】723- 前端如何优雅的处理类数组对象?
- GitLabCI作业中如何使用私有仓库镜像?
- 三分钟学会自定义spring-boot-starter
- 分析Netflix公司产品Spinnaker的微服务实践