当前位置: 首页 > news >正文

子洲网站建设平台马鞍山什么房产网站做的好

子洲网站建设平台,马鞍山什么房产网站做的好,桂阳网站设计,网络营销的企业有哪些总结了以下六种常用的Android延时执行策略,以此记录: 1、TimerTask 2、Handler.postDelayed 3、Handler.sendEnptyMessageDelayeed 4、Thread.sleep线程休眠-需要在子线程 5、使用AlarmManager-全局定时器或者闹钟 6、Wait 首先定义一个时间常量&…

总结了以下六种常用的Android延时执行策略,以此记录:

1、TimerTask

2、Handler.postDelayed

3、Handler.sendEnptyMessageDelayeed

4、Thread.sleep线程休眠-需要在子线程

5、使用AlarmManager-定时器或者闹钟

6、Wait

首先定义一个时间常量:

public static final long DELAYTIME = 2000L;

1、TimerTask

TimerTask mTimerTask = new TimerTask() {@Overridepublic void run() {Log.e(TAG, "TimerTask -run:");}};
//timer可以复用,timerTask不可复用,否则闪退
if (mTimer ==null){mTimer = new Timer();
}
mTimer.schedule(mTimerTask,DELAYTIME);Handler.postDelayed
handler.postDelayed(new Runnable() {@Overridepublic void run() {Log.e(TAG, "handler.postDelayed :");}
},DELAYTIME);

注意:以上用法timer可以复用,timerTask不可复用。

第二种和第三中都依赖Handler,先定义一个handler

public static class MyHandler extends Handler{private final WeakReference<Activity> activityWeak;public MyHandler(Activity activity){activityWeak = new WeakReference<>(activity);}@Overridepublic void handleMessage(@NonNull Message msg) {super.handleMessage(msg);TimerActivity activity = (TimerActivity) activityWeak.get();switch (msg.what){case TimerActivity.MESSAGE1:Log.e(TAG, "handleMessage: what="+msg.what );break;default:Log.e(TAG, "handleMessage:      default      -what="+msg.what );break;}}
}

2、Handler.postDelayed

handler.postDelayed(new Runnable() {@Overridepublic void run() {Log.e(TAG, "handler.postDelayed :");}
},DELAYTIME);

3、Handler.sendEnptyMessageDelayeed

Log.e(TAG, "handler.sendEmptyMessageAtTime :start");
handler.sendEmptyMessageDelayed(MESSAGE1,DELAYTIME);
Log.e(TAG, "handler.sendEmptyMessageAtTime :");

4、Thread.sleep线程休眠-需要在子线程,sleep是线程的方法,他休眠中不会释放锁

Log.e(TAG, "Thread.sleep:  onClick" );
Object lock = new Object();
new Thread() {@Overridepublic void run() {super.run();try {synchronized (lock){Log.e(TAG, "Thread.sleep:  子线程start" );Thread.sleep(20000);Log.e(TAG, "Thread.sleep:  子线程end" );}} catch (InterruptedException e) {e.printStackTrace();}}
}.start();
try {Log.e(TAG, "Thread.sleep:  onClick-1" );Thread.sleep(200);//此行代码影响甚大,需灵活注释,
虽然上面new Thread耗时很短,但是也是有一定开销足以让它在主线程顺序之后执行Log.e(TAG, "Thread.sleep:  主线程执行-准备获取锁" );synchronized (lock){Log.e(TAG, "Thread.sleep:  主线程已获得锁" );}Log.e(TAG, "Thread.sleep:  主线程已释放锁锁" );
} catch (InterruptedException e) {e.printStackTrace();
}

主线程没有200毫秒延时也就是注释Thread.sleep(200)就会先执行主线程然后进入子线程,虽然上面new Thread耗时很短,但是也是有一定开销足以让它在主线程顺序之后执行,以上代码测试发现从new Thread到子线程内第一行代码执行耗时不足1毫秒。以下是运行日志:
2023-12-11 15:12:26.944 18617-18617/com.example.testdemo3 E/com.example.testdemo3.activity.TimerActivity: Thread.sleep:  onClick
2023-12-11 15:12:26.945 18617-18617/com.example.testdemo3 E/com.example.testdemo3.activity.TimerActivity: Thread.sleep:  onClick-1
2023-12-11 15:12:26.945 18617-18617/com.example.testdemo3 E/com.example.testdemo3.activity.TimerActivity: Thread.sleep:  主线程执行-准备获取锁
2023-12-11 15:12:26.946 18617-18617/com.example.testdemo3 E/com.example.testdemo3.activity.TimerActivity: Thread.sleep:  主线程已获得锁
2023-12-11 15:12:26.946 18617-18919/com.example.testdemo3 E/com.example.testdemo3.activity.TimerActivity: Thread.sleep:  子线程start
2023-12-11 15:12:46.947 18617-18919/com.example.testdemo3 E/com.example.testdemo3.activity.TimerActivity: Thread.sleep:  子线程end

======================================

 主线程有200毫秒延时也就是不注释Thread.sleep(200),就会先进入子线程执行完

然后进入主线程。以下是运行日志:
2023-12-11 15:09:40.785 17990-17990/com.example.testdemo3 E/com.example.testdemo3.activity.TimerActivity: Thread.sleep:  onClick
 2023-12-11 15:09:40.786 17990-17990/com.example.testdemo3 E/com.example.testdemo3.activity.TimerActivity: Thread.sleep:  onClick-1
 2023-12-11 15:09:40.786 17990-18231/com.example.testdemo3 E/com.example.testdemo3.activity.TimerActivity: Thread.sleep:  子线程start
 2023-12-11 15:09:40.987 17990-17990/com.example.testdemo3 E/com.example.testdemo3.activity.TimerActivity: Thread.sleep:  主线程执行-准备获取锁
 2023-12-11 15:10:00.787 17990-18231/com.example.testdemo3 E/com.example.testdemo3.activity.TimerActivity: Thread.sleep:  子线程end
 2023-12-11 15:10:00.787 17990-17990/com.example.testdemo3 E/com.example.testdemo3.activity.TimerActivity: Thread.sleep:  主线程已获得锁

5、使用AlarmManager-定时器或者闹钟。适用一直在后台运行的定时任务,此处放在一个service执行

Intent intent = new Intent();
intent.setAction("short");
ComponentName component = new ComponentName(TimerActivity.this, MyReceiver.class);
intent.setComponent(component);
//这里除了启动广播也可以换成启动Activity和service
PendingIntent sender = PendingIntent.getBroadcast(TimerActivity.this,0,intent,0);Calendar calendar = Calendar.getInstance();
calendar.setTimeInMillis(System.currentTimeMillis());
calendar.add(Calendar.SECOND,5);
AlarmManager alarmManager = (AlarmManager) getSystemService(ALARM_SERVICE);
alarmManager.set(AlarmManager.RTC_WAKEUP,System.currentTimeMillis(),sender);

6、Wait-必须使用synchronized,他是Object的方法,他休眠会释放锁

 Object lock = new Object();new Thread(){@Overridepublic void run() {super.run();try {
//                            synchronized (lock){  //没有synchronized锁就会报错:java.lang.IllegalMonitorStateException: object not locked by thread before wait()Log.e(TAG, "Thread.wait:  start" );//以下两行需灵活注释lock.wait(2000);
//                                Thread.sleep(2000);Log.e(TAG, "Thread.wait:  end" );
//                            }} catch (Exception e) {e.printStackTrace();}Log.e(TAG, "Thread.wait:  子线程第二条" );}}.start();try {Thread.sleep(200);Log.e(TAG, "Thread.wait:  主线程开始获取锁" );synchronized (lock){Log.e(TAG, "Thread.wait:  主线程已获得锁" );}} catch (InterruptedException e) {e.printStackTrace();}

lock.wait(2000)放开,Thread.sleep(2000)注释,日志如下:
2023-12-11 14:21:34.371 9385-9748/com.example.testdemo3 E/com.example.testdemo3.activity.TimerActivity: Thread.wait:  start
2023-12-11 14:21:34.571 9385-9385/com.example.testdemo3 E/com.example.testdemo3.activity.TimerActivity: Thread.wait:  主线程开始获取锁
2023-12-11 14:21:34.571 9385-9385/com.example.testdemo3 E/com.example.testdemo3.activity.TimerActivity: Thread.wait:  主线程已获得锁
2023-12-11 14:21:36.372 9385-9748/com.example.testdemo3 E/com.example.testdemo3.activity.TimerActivity: Thread.wait:  end
2023-12-11 14:21:36.372 9385-9748/com.example.testdemo3 E/com.example.testdemo3.activity.TimerActivity: Thread.wait:  子线程第二条

Thread.sleep(2000)放开,lock.wait(2000)注释,日志如下:

sleep是线程的方法,他休眠中不会释放锁
2023-12-11 14:24:27.519 10346-10750/com.example.testdemo3 E/com.example.testdemo3.activity.TimerActivity: Thread.wait:  start
2023-12-11 14:24:27.719 10346-10346/com.example.testdemo3 E/com.example.testdemo3.activity.TimerActivity: Thread.wait:  主线程开始获取锁
2023-12-11 14:24:29.520 10346-10750/com.example.testdemo3 E/com.example.testdemo3.activity.TimerActivity: Thread.wait:  end
2023-12-11 14:24:29.520 10346-10750/com.example.testdemo3 E/com.example.testdemo3.activity.TimerActivity: Thread.wait:  子线程第二条
2023-12-11 14:24:29.520 10346-10346/com.example.testdemo3 E/com.example.testdemo3.activity.TimerActivity: Thread.wait:  主线程已获得锁

http://www.yayakq.cn/news/941883/

相关文章:

  • 烟台网站制作开发垂直电商网站开发
  • 电脑网站设计公司中国建设传媒网
  • 嘉兴建站模板系统系部网站开发计划
  • 如何做响应式网站视频教程成都交投成高建设公司网站
  • 中国网站设计免费字体设计图片
  • 简单展示网站模板设计logo商标
  • 深圳公司网站设企业网站设计专业好吗
  • 济南做网站的机构有哪些wordpress 注册密码
  • 如何做网站路径分析天津建设科技杂志的官方网站
  • 网站开发网页设计游戏设计婚纱网站策划书模板下载
  • 用dede做的网站首页珠宝网站建设需求
  • 网站建设心得体会及总结手机网站的作用
  • wordpress网站安全性制作网页的软件有
  • 石青网站推广软件创建个人商城网站
  • 网站制作商成都网络营销策划公司
  • 浙江建设监理协会网站网页设计毕设
  • 保障性住房建设投资中心网站江苏网站建设系统服务
  • 湖南网站建设费用网站界面设计起着决定性作用
  • 推广网站的软文上海松江区做网站公司
  • 哈尔滨市建设工程交易中心网站什么网站都能进的浏览器
  • asp网站耗资源张家界做网站的人
  • 福安城乡建设与规划局网站新浪wordpress
  • 西安网站运营天眼查企业查询在线官网
  • 个人网站可以做淘宝客中国新闻社和新华社有什么区别
  • 营销型网站教程温州网站建设
  • vps里面怎么建立网站wordpress中文用户名注册
  • dede做招聘网站三星手机网上商城
  • 做网站需要掌握什么软件中国建设银行网站如何注册
  • 网站常用布局wordpress免费主题网站
  • 做淘宝客网站的流程网站备案密码忘