但是用户很可能连续点击两下,那样 ActivityB就启动两个(在B是standard 启动模式),且用户若想回到ActivityA则需要点击返回键,这显然并不是一个特别好的体验。想必很多小伙伴都遇到过,解决方法自然就是通过 时间来判断,在一定时间内禁止操作。 不过总不能在每个方法里都写一遍 时间判断吧。如这样
long lastTime = 0;
void handleClick(){
long currentTime = System.currentTimeMillis();
if ( currentTime - lastTime < 200){
return;
}
//具体操作
…
}
这种常用的方法,自然是要抽象一个类出来了。
public class OperateLock {
private final static long DEFAULT_PERIOD = 200;
private final long period;
private long lastOperatorTime = 0;
public OperateLock() {
period = DEFAULT_PERIOD;
}
public OperateLock(int minimumPeriod) {
period = minimumPeriod;
}
public boolean doing() {
boolean doing = false;
long currentTime = System.currentTimeMillis();
if (currentTime - lastOperatorTime > period) {
lastOperatorTime = currentTime;
doing = true;
}
return doing;
}
public boolean doing(int minimumPeriod) {
boolean doing = false;
long currentTime = System.currentTimeMillis();
if (currentTime - lastOperatorTime > minimumPeriod) {
lastOperatorTime = currentTime;
doing = true;
}
return doing;
}
}
如上代码,就可以改成
private OperateLock operateLock = new OperateLock();
void handleClick(){
if (!operateLock.doing()) return;
//具体操作
…
}
不过以上代码在遇到很多个button的情况下,显然就要写很多个 operate 对象了,这显然也太多了,so,我们继续修改代码
public class ObjectOperateLock {
private final static long DEFAULT_PERIOD = 200;
private final long period;
private long lastOperatorTime = 0;
private List< WeakReference > operateObjList = new LinkedList<>();
private HashMap< WeakReference, Long > timeHashMap = new HashMap<>();
public ObjectOperateLock() {
period = DEFAULT_PERIOD;
Object obj = new Object();
}
public ObjectOperateLock(int minimumPeriod) {
period = minimumPeriod;
}
public boolean doing(Object obj) {
doing(obj, period);
}
public boolean doing(Object obj, long minimumPeriod) {
boolean doing = false;
long lastOperateTime = 0;
WeakReference wk = null;
Iterator< WeakReference > iterator = operateObjList.iterator();
while (iterator.hasNext()) {
WeakReference w = iterator.next();
if (w.get() == null) {
iterator.remove();
timeHashMap.remove(w);
} else if (w.get() == obj) {
wk = w;
}
}
if (wk == null) {
wk = new WeakReference(obj);
operateObjList.add(wk);
timeHashMap.put(wk, 0L);
doing = true;
} else {
long cur = System.currentTimeMillis();
lastOperateTime = timeHashMap.get(wk);
if (cur - lastOperateTime > minimumPeriod) {
doing = true;
lastOperateTime = cur;
timeHashMap.put(wk, lastOperateTime);
}
}
return doing;
}
}
拦截频繁点击代码改为:
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此我收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
提升的进阶课程,基本涵盖了95%以上Android开发知识点!不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门**
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!