当遇到按钮频繁点击、或是某些监听实时变化的方法时,往往只需要执行最后一次方法的调用的场景。
比如,如果用户在2秒内频繁点击按钮,只需要执行用户最后一次点击的操作,也就是在2s内的点击事件都会被取消。
解决方法1.手动实现NSTimer
创建NSTimer
,记录用户两次操作执行的时间间隔,小于2秒,将NSTimer
取消,重新开始计算,在没有新的点击时,2s后再执行方法即可。不推荐~
解决方法2.对当前Run Loop中Selector Sources的取消
NSObject
中的performSelector:withObject:afterDelay:
方法将会在当前线程的Run Loop
中根据afterDelay
参数创建一个Timer
,如果没有调用有inModes
参数的方法,该Timer
会运行在当前Run Loop
的默认模式中,也就是NSDefaultRunLoopMode
定义的模式中。
performSelector:withObject:afterDelay:
方法的使用看起来还是很简单的。这里讲另外一个辅助函数,NSObject
中静态的cancelPreviousPerformRequestsWithTarget
方法。该方法就是专门用来取消performSelector:withObject:afterDelay:
方法所创建的Selector source
(内部上就是一个Run Loop
的Timer source
)。因此该方法和performSelector:withObject:afterDelay:
方法一样,只限于当前Run Loop
中。
我们可以利用cancelPreviousPerformRequestsWithTarget
直接取消一个对象在当前Run Loop中的所有未执行的performSelector:withObject:afterDelay:
方法所产生的Selector Sources
,如下代码:
- (void)viewDidLoad {
[super viewDidLoad];
}
- (void)action:(UIButton *)button {
[self.class cancelPreviousPerformRequestsWithTarget:self selector:@selector(buttonAction) object:nil];
// 0.5秒后发起查询
[self performSelector:@selector(buttonAction) withObject:nil afterDelay:0.5];
}
在0.5s内的点击,实际上都被取消掉了。