使用GCD 实现倒计时功能

前段时间需要实现倒计时功能,找了一下网上用NSTimer的比较多,但是实际上,NSTimer的计算倒数不准确,NSTimer受runloop的影响,由于runloop需要处理很多任务,导致NSTimer的精度降低。所有就考虑用GCD来实现此功能。实现后发现确实比NSTimer准确,而且也不麻烦,不废话 上代码。

先创建一个source源

@property (nonatomic, strong) dispatch_source_t countdownTimer;

这个表示点击时间
然后再写一个方法,用来执行倒计时功能

-(void)countDownWithTimer:(dispatch_source_t)timer timeInterval:(NSTimeInterval)timeInterval complete:(void(^)())completeBlock progress:(void(^)(int mDay, int mHours, int mMinute, int mSecond))progressBlock{
    __block int timeout = timeInterval; //倒计时时间
    if (timeout!=0) {
        dispatch_source_set_timer(timer,dispatch_walltime(NULL, 0),1.0*NSEC_PER_SEC, 0); //每秒执行
        dispatch_source_set_event_handler(timer, ^{
            if(timeout<=0){ //倒计时结束,关闭
                dispatch_source_cancel(timer);
                dispatch_async(dispatch_get_main_queue(), ^{ // block 回调
                    if (completeBlock) {
                        completeBlock();
                    }
                });
            }else{
                int days = (int)(timeout/(3600*24));
                int hours = (int)((timeout-days*24*3600)/3600);
                int minute = (int)(timeout-days*24*3600-hours*3600)/60;
                int second = timeout-days*24*3600-hours*3600-minute*60;
                dispatch_async(dispatch_get_main_queue(), ^{
                    if (progressBlock) { //进度回调
                        progressBlock(days, hours, minute, second);
                    }
                });
                timeout--;
            }
        });
        dispatch_resume(timer);
    }
}

第一个参数就是我们的source源,第二个参数是需要倒计时的时间 如60秒。

然后写调用倒计时方法的方法

// 调用方法
-(void)resetCountdown:(NSInteger)time{
    [self cancelCountdownTimer];// 取消操作
    NSInteger count = time;
        // 创建一个队列
        dispatch_queue_t queue = dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0);
        _countdownTimer = dispatch_source_create(DISPATCH_SOURCE_TYPE_TIMER, 0, 0,queue);
        [self countDownWithTimer:_countdownTimer timeInterval:count complete:^{
            // 完成执行操作
        } progress:^(int mDay, int mHours, int mMinute, int mSecond) {
            NSLog(@"倒计时:%d", mSecond);
            // 倒计时

        }];
}

最后写一个取消方法

// 取消操作
-(void)cancelCountdownTimer{
    if (_countdownTimer) {
        dispatch_source_cancel(_countdownTimer);
        _countdownTimer = nil;
    }
}

这样 就完成了GCD的倒计时实现方法
so finish。。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: gcd(最大公约数)算法的实现代码可以使用辗转相除法来实现。 这是一种递归算法,它的基本思想是用两个数的较小值去除较大值,然后把所得的余数作为新的较小值,较大值不变,再次进行除法运算,直到余数为 0 为止。最后较大值就是两个数的最大公约数。 下面是 Python 中 gcd 算法的实现代码: ``` def gcd(a, b): if b == 0: return a else: return gcd(b, a % b) ``` 在这段代码中,a 和 b 是要求最大公约数的两个数。如果 b 等于 0,则返回 a,否则返回 gcd(b, a % b)。a % b 表示 a 除以 b 的余数。 例如,计算 gcd(24, 16) 的过程如下: - gcd(24, 16) -> gcd(16, 8) -> gcd(8, 0) -> 8 所以 gcd(24, 16) = 8。 希望这能帮到你! ### 回答2: gcd算法,也叫做欧几里德算法,是用来求两个整数的最大公约数的算法。 实现gcd算法的代码如下: ```python def gcd(a, b): while b != 0: a, b = b, a % b return a ``` 以上代码使用了辗转相除法来求最大公约数。首先将较大的数赋值给a,较小的数赋值给b。然后用a对b进行取余运算,得到的结果再赋值给a。这样反复进行,直到b等于0为止。 举个例子,假设要求解40和24的最大公约数。按照gcd算法的实现代码,代码执行过程如下: 1. a = 40, b = 24。40对24取余,得到16,赋值给a。现在a = 16, b = 24。 2. a = 24, b = 16。24对16取余,得到8,赋值给a。现在a = 8, b = 16。 3. a = 16, b = 8。16对8取余,得到0,赋值给a。现在a = 0, b = 8。 由于b等于0,所以最终的结果是a,即8。所以40和24的最大公约数就是8。 以上就是实现gcd算法的代码和算法过程。通过这段代码,我们能够快速求解两个整数的最大公约数。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值