網(wǎng)站首頁 編程語言 正文
前言
android開發(fā)中,常用定時器實現(xiàn)方式有以下幾種:
1、Handler與sleep
2、Handler與postDelayed
3、Handler與timer
注:Handler的主要作用就是用來處理接收到的信息;用Handler消息傳遞機制是為了多個線程并發(fā)更新UI的同時,保證線程安全;
一、Handler 與 sleep
public class HandlerAndSleep {
// 1、定義一個Handler類,用于處理接受到的Message.
Handler handler = new Handler(Looper.getMainLooper()) {
@Override
public void handleMessage(@NonNull Message msg) {
super.handleMessage(msg);
// do something eg.
Log.d("HandlerAndSleep", "HandlerAndSleep");
}
};
// 2、新建一個實現(xiàn)Runnable接口的線程類
class MyThread implements Runnable {
@Override
public void run() {
while (true) {
try {
Thread.sleep(10000);
Message message = new Message();
message.what = 1;
handler.sendMessage(message);
} catch (Exception e) {
e.printStackTrace();
}
}
}
}
public HandlerAndSleep() {
//3、在需要啟動線程的地方加入下面語句,啟動線程后,線程每10s發(fā)送一次消息
new Thread(new MyThread()).start();
}
}
結果打印如下:
2022-05-30 11:30:42.320 17864-17864/com.yh.study D/HandlerAndSleep: HandlerAndSleep
2022-05-30 11:30:52.324 17864-17864/com.yh.study D/HandlerAndSleep: HandlerAndSleep
2022-05-30 11:31:02.326 17864-17864/com.yh.study D/HandlerAndSleep: HandlerAndSleep
2022-05-30 11:31:12.335 17864-17864/com.yh.study D/HandlerAndSleep: HandlerAndSleep
2022-05-30 11:31:22.338 17864-17864/com.yh.study D/HandlerAndSleep: HandlerAndSleep
2022-05-30 11:31:32.339 17864-17864/com.yh.study D/HandlerAndSleep: HandlerAndSleep
2022-05-30 11:31:42.347 17864-17864/com.yh.study D/HandlerAndSleep: HandlerAndSleep
二、Handler 與 postDelayed
public class HandleAndPostDelayed {
Handler handler = new Handler(){
@Override
public boolean sendMessageAtTime(@NonNull Message msg, long uptimeMillis) {
Log.d("HandleAndPostDelayed", "HandleAndPostDelayed");
return super.sendMessageAtTime(msg, uptimeMillis);
}
};
Runnable runnable = new Runnable() {
@Override
public void run() {
// do something
handler.postDelayed(this, 2000);
}
};
HandleAndPostDelayed() {
// 開啟定時器
handler.postDelayed(runnable, 2000);
// 停止定時器
// handler.removeCallbacks(runnable);
}
}
結果打印如下:
2022-05-30 14:32:41.533 24351-24351/com.yh.study D/HandleAndPostDelayed: HandleAndPostDelayed
2022-05-30 14:32:43.534 24351-24351/com.yh.study D/HandleAndPostDelayed: HandleAndPostDelayed
2022-05-30 14:32:45.537 24351-24351/com.yh.study D/HandleAndPostDelayed: HandleAndPostDelayed
2022-05-30 14:32:47.539 24351-24351/com.yh.study D/HandleAndPostDelayed: HandleAndPostDelayed
2022-05-30 14:32:49.546 24351-24351/com.yh.study D/HandleAndPostDelayed: HandleAndPostDelayed
2022-05-30 14:32:51.550 24351-24351/com.yh.study D/HandleAndPostDelayed: HandleAndPostDelayed
三、Handler 與 timer
public class HandlerAndTimer {
private final Timer timer = new Timer();
private TimerTask task;
Handler handler = new Handler() {
@Override
public void handleMessage(@NonNull Message msg) {
// do something
Log.d("HandlerAndTimer", "HandlerAndTimer");
super.handleMessage(msg);
}
};
public HandlerAndTimer() {
task = new TimerTask() {
@Override
public void run() {
Message message = new Message();
message.what = 1;
handler.sendMessage(message);
}
};
//啟動定時器 參數(shù)對應為 TimerTask 延遲時間 間隔時間
timer.schedule(task, 2000, 2000);
}
}
結果打印如下:
2022-05-30 14:43:40.922 25052-25052/com.yh.study D/HandlerAndTimer: HandlerAndTimer
2022-05-30 14:43:42.924 25052-25052/com.yh.study D/HandlerAndTimer: HandlerAndTimer
2022-05-30 14:43:44.925 25052-25052/com.yh.study D/HandlerAndTimer: HandlerAndTimer
2022-05-30 14:43:46.926 25052-25052/com.yh.study D/HandlerAndTimer: HandlerAndTimer
2022-05-30 14:43:48.927 25052-25052/com.yh.study D/HandlerAndTimer: HandlerAndTimer
在Android上常用的定時器有兩種,一種是Java.util.Timer,一種就是系統(tǒng)的AlarmService。
public class MainActivity extends AppCompatActivity {
Handler handler = new Handler() {
@Override
public void handleMessage(@NonNull Message msg) {
tCount++;
timerTV.setText(tCount+"");
super.handleMessage(msg);
}
};
Timer timer = new Timer();
int tCount = 0;
int sCount = 0;
TextView timerTV;
TextView serviceTV;
String ALARM_RECEIVER_ACTION = "com.yh.study.AlarmReceiver";
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
timerTV = findViewById(R.id.timer_tv);
serviceTV = findViewById(R.id.service_tv);
timer.schedule(new TimerTask() {
@Override
public void run() {
handler.sendEmptyMessage(0);
}
}, 2*1000, 5*1000);
AlarmReceiver alarmReceiver = new AlarmReceiver(new Handler() {
@Override
public void handleMessage(@NonNull Message msg) {
sCount++;
serviceTV.setText(sCount+"");
super.handleMessage(msg);
}
});
IntentFilter intentFilter = new IntentFilter();
intentFilter.addAction(ALARM_RECEIVER_ACTION);
registerReceiver(alarmReceiver, intentFilter);
Intent intent = new Intent(ALARM_RECEIVER_ACTION);
PendingIntent pendingIntent = PendingIntent.getBroadcast(MainActivity.this, 0, intent, 0);
//
AlarmManager alarmManager = (AlarmManager) getSystemService(ALARM_SERVICE);
alarmManager.setExactAndAllowWhileIdle(AlarmManager.ELAPSED_REALTIME_WAKEUP, SystemClock.elapsedRealtime(),
pendingIntent);
}
}
public class AlarmReceiver extends BroadcastReceiver {
Handler handler;
AlarmReceiver(Handler handler) {
this.handler = handler;
}
@Override
public void onReceive(Context context, Intent intent) {
Log.d("onReceive", "onReceive");
handler.sendEmptyMessage(0);
Intent serviceIntent = new Intent(context, MyService.class);
context.startService(serviceIntent);
}
}
public class MyService extends IntentService {
public MyService() {
super("MyService");
}
@Override
protected void onHandleIntent(@Nullable Intent intent) {
AlarmManager alarmManager = (AlarmManager) getSystemService(Context.ALARM_SERVICE);
Intent alarmIntent = new Intent("com.yh.study.AlarmReceiver");
PendingIntent pendingIntent = PendingIntent.getBroadcast(this, 0, alarmIntent, 0);
alarmManager.setExactAndAllowWhileIdle(AlarmManager.RTC_WAKEUP, System.currentTimeMillis()+5*1000,
pendingIntent);
}
}
以下結論來源其他博主
(小子在驗證過程中,連接usb情況正常,拔掉usb后與結論不符,可能是小子哪里寫的有問題)
在Timer中,當連接USB線進行調試時,會發(fā)現(xiàn)一切工作正常,每5秒更新一次界面,即使是按下電源鍵,仍然會5秒觸發(fā)一次。 當拔掉USB線,按下電源鍵關閉屏幕后,過一段時間再打開,發(fā)現(xiàn)定時器明顯沒有繼續(xù)計數(shù),停留在了關閉電源鍵時的數(shù)字。
在AlarmService中,拔掉USB線,按下電源鍵,過一點時間再次打開屏幕,發(fā)現(xiàn)定時器一直在計數(shù)。
測試機型小米8,上timer,下AlarmService
補充:采用Handler與timer及TimerTask結合的方法
1. 定義定時器、定時器任務及Handler句柄
private final Timer timer = new Timer();
private TimerTask task;
Handler handler = new Handler() {
@Override
public void handleMessage(Message msg) {
// TODO Auto-generated method stub
// 要做的事情
super.handleMessage(msg);
}
};
2. 初始化計時器任務
task = new TimerTask() {
@Override
public void run() {
// TODO Auto-generated method stub
Message message = new Message();
message.what = 1;
handler.sendMessage(message);
}
};
3. 啟動定時器
timer.schedule(task, 2000, 2000);
總結?
原文鏈接:https://blog.csdn.net/Twan1234/article/details/125050488
相關推薦
- 2022-12-02 C語言學習之指針的使用詳解_C 語言
- 2022-05-18 C語言模擬內存函數(shù)分析之mencpy與memmove_C 語言
- 2023-02-25 Golang合并yaml文件過程逐步講解_Golang
- 2022-09-01 jquery實現(xiàn)全選功能_jquery
- 2022-08-26 C++類模板實戰(zhàn)之vector容器的實現(xiàn)_C 語言
- 2022-04-26 Jquery+bootstrap實現(xiàn)表格行置頂置底上移下移操作詳解_jquery
- 2022-02-18 微信小程序----------父組件調用子組件的方法
- 2023-01-19 詳解Go語言實現(xiàn)線性查找算法和二分查找算法_Golang
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學習環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結構-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支