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;
}
}
拦截频繁点击代码改为:
private ObjectOperateLock operateLock = new ObjectOperateLock();
void handleClickButton1(View v){
if (!operateLock.doing(v)) return;
//具体操作
…
}
void handleClickButton2(View v){
if (!operateLock.doing(v)) return;
//具体操作
…
}
当然,ObjectOperateLock
中所有方法也可以改为静态的,但是那样不利于设置一个默认的周期,比如 某几个 button可能是要 200毫秒以内只能点击一次,但是另一些View 则是500毫秒内只能点击一次。 那么既然使用了 ObjectOperateLock
是不是就不需要用 OperateLock
了,当然不是 OperateLock
也有其用处。
场景2
有一个 RecyclerView ,其有一堆 item,item 点击后会跳进一个页面,item携带的数据是不同的,那如何拦截item的频繁点击呢。
相对于场景1,此种场景下,会出现一个问题,即,存在 两个 item同时被点击的情况。(两个手指同时点击不同的 item).这种情况,就可以用 OperateLock
。
private OperateLock operateLock = new OperateLock();
void handleItemClick(View v){
if (!operateLock.doing()) return;
}
总结
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则近万的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注:Android)
总结
作为一名从事Android的开发者,很多人最近都在和我吐槽Android是不是快要凉了?而在我看来这正是市场成熟的表现,所有的市场都是温水煮青蛙,永远会淘汰掉不愿意学习改变,安于现状的那批人,希望所有的人能在大浪淘沙中留下来,因为对于市场的逐渐成熟,平凡并不是我们唯一的答案!
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门即可获取!
掉不愿意学习改变,安于现状的那批人,希望所有的人能在大浪淘沙中留下来,因为对于市场的逐渐成熟,平凡并不是我们唯一的答案!
[外链图片转存中…(img-k9xjSstu-1712155160093)]
[外链图片转存中…(img-hqkrrQ48-1712155160093)]