基于dispatch_after封装YXTimer

本人根据dispatch_after封装了一个定时器,支持block以及代理的方式来激活定时器,适用于对精度要求低,耗时短的地方,高端大气上档次,低调奢华有内涵:)

源码:

YXTimer.h 与 YXTimer.m

//
// YXTimer.h
// YXTimer
//
// Created by YouXianMing on 14-10-2.
// Copyright (c) 2014年 YouXianMing. All rights reserved.
// #import <Foundation/Foundation.h>
@class YXTimer; @protocol YXTimerDelegete <NSObject>
- (void)YXTimerEvent:(YXTimer *)timer;
@end @interface YXTimer : NSObject // 代理相关方法
@property (nonatomic) NSTimeInterval milliSecond; // 毫秒
@property (nonatomic, assign) id<YXTimerDelegete> delegate; // block相关方法
+ (instancetype)timerWithMilliSecondInterval:(NSTimeInterval)milliSecond
Block:(void (^)(YXTimer *timer))block; // 激活定时器 + 停止定时器
- (void)start;
- (void)stop; // 注意:要想让timer能被移除,一定要激活stop方法才行 @end
//
// YXTimer.m
// YXTimer
//
// Created by YouXianMing on 14-10-2.
// Copyright (c) 2014年 YouXianMing. All rights reserved.
// #ifdef DEBUG
#define YXTimer_DLog(fmt, ...) NSLog((@"YXTimer.m:%s:%d" fmt), __PRETTY_FUNCTION__, __LINE__, ##__VA_ARGS__);
#else
#define YXTimer_DLog(...)
#endif #import "YXTimer.h" @interface YXTimer () @property (nonatomic) BOOL isRunning;
@property (nonatomic, copy) void (^block)(YXTimer *timer); @end @implementation YXTimer - (instancetype)init
{
self = [super init];
if (self) {
_isRunning = NO;
}
return self;
} - (instancetype)initWithBlock:(void (^)(YXTimer *timer))block {
self = [super init]; if (self) {
_isRunning = NO;
_block = block;
} return self;
} - (void)start {
_isRunning = YES;
[self runTimer];
} - (void)stop {
_isRunning = NO;
} + (instancetype)timerWithMilliSecondInterval:(NSTimeInterval)milliSecond
Block:(void (^)(YXTimer *timer))block {
YXTimer *timer = [[YXTimer alloc] initWithBlock:block];
timer.milliSecond = milliSecond; return timer;
} - (void)runTimer { if (self.isRunning) { NSTimeInterval milliSecond = .f;
if (_milliSecond > ) {
milliSecond = _milliSecond;
} dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(milliSecond * NSEC_PER_MSEC)), dispatch_get_main_queue(), ^{
if (self.block) {
self.block(self);
} if (_delegate) {
[_delegate YXTimerEvent:self];
} [self runTimer];
});
}
} - (void)dealloc {
[self stop];
YXTimer_DLog(@"资源释放了");
} @end

使用源码:

//
// ViewController.m
// YXTimer
//
// Created by YouXianMing on 14-10-2.
// Copyright (c) 2014年 YouXianMing. All rights reserved.
// #import "ViewController.h"
#import "YXTimer.h" @interface ViewController ()<YXTimerDelegete> @property (nonatomic, strong) YXTimer *timer;
@property (nonatomic, strong) UILabel *label;
@property (nonatomic, strong) NSArray *dataArray;
@property (nonatomic) NSInteger count; @end @implementation ViewController - (void)viewDidLoad {
[super viewDidLoad]; _dataArray = @[@"Y.X. Loading .",
@"Y.X. Loading ..",
@"Y.X. Loading ...",
@"Y.X. Loading ....",
@"Y.X. Loading .....",
@"Y.X. Loading ......",
@"Y.X. Loading ......."]; _timer = [YXTimer new];
_timer.milliSecond = ;
_timer.delegate = self;
[_timer start]; _label = [[UILabel alloc] initWithFrame:CGRectMake(, , , )];
_label.textAlignment = NSTextAlignmentLeft;
_label.font = [UIFont fontWithName:@"HelveticaNeue-Thin" size:.f];
_label.textColor = [UIColor redColor];
_label.center = self.view.center;
[self.view addSubview:_label]; } - (void)YXTimerEvent:(YXTimer *)timer
{
_label.text = _dataArray[_count++ % _dataArray.count];
} @end

需要注意的地方:

基于dispatch_after封装YXTimer的更多相关文章

  1. 基于highcharts封装的组件-demo&源码

    前段时间做的项目中需要用到highcharts绘制各种图表,其实绘制图表本身代码很简单,但是由于需求很多,有大量的图形需要绘制,所以就不得不复制粘贴大量重复(默认配置等等)的代码,所以,后来抽空自己基 ...

  2. 基于jQuery封装的分页组件

    前言: 由于项目需要实现分页效果,上jQuery插件库找了下,但是木有找到自己想要的效果,于是自己封装了个分页组件. 思路: 主要是初始化时基于原型建立的分页模板然后绑定动态事件并实现刷新DOM的分页 ...

  3. 基于AFN封装的带缓存的网络请求

    给大家分享一个基于AFN封装的网络请求 git: https://github.com/zhouxihi/NVNetworking #带缓存机制的网络请求 各类请求有分带缓存 , 不带缓存, 可自定义 ...

  4. 基于vue-simple-uploader封装文件分片上传、秒传及断点续传的全局上传插件

    目录 1. 前言 2. 关于vue-simple-uploader 3. 基于vue-simple-uploader封装全局上传组件 4. 文件上传流程概览 5. 文件分片 6. MD5的计算过程 7 ...

  5. 基于epoll封装的事件回调miniserver

    epoll技术前两节已经阐述过了,目前主要做一下封装,很多epoll的服务器都是采用事件回调方式处理, 其实并没有什么复杂的,我慢慢给大家阐述下原理. 在networking.h和networking ...

  6. vue可视化图表 基于Echarts封装好的v-charts简介

    **vue可视化图表 基于Echarts封装好的v-charts** 近期公司又一个新的需求,要做一个订单和销售额统计的项目,需要用到可视化图表来更直观的展示数据.首先我想到的是Echarts,众所周 ...

  7. EasyRTSPClient:基于live555封装的支持重连的RTSP客户端RTSPClient

    今天先简单介绍一下EasyRTSPClient,后面的文章我们再仔细介绍EasyRTSPClient内部的设计过程: EasyRTSPClient:https://github.com/EasyDar ...

  8. 基于better-scroll封装一个上拉加载下拉刷新组件

    1.起因 上拉加载和下拉刷新在移动端项目中是很常见的需求,遂自己便基于better-scroll封装了一个下拉刷新上拉加载组件. 2.过程 better-scroll是目前比较好用的开源滚动库,提供很 ...

  9. Python3操作MySQL基于PyMySQL封装的类

    Python3操作MySQL基于PyMySQL封装的类   在未使用操作数据库的框架开发项目的时候,我们需要自己处理数据库连接问题,今天在做一个Python的演示项目,写一个操作MySQL数据库的类, ...

随机推荐

  1. C++中迭代器原理、失效和简单实现

    目录 迭代器的使用 迭代器的种类 迭代器的失效 迭代器的实现 1.迭代器的使用 为了提高C++编程的效率,STL中提供了许多容器,包括vector.list.map.set等.有些容器例如vector ...

  2. Date类学习总结(Calendar Date 字符串 相互转换 格式化)

    Date类学习总结 1.计算某一月份的最大天数 Calendar time=Calendar.getInstance();time.clear();time.set(Calendar.YEAR,yea ...

  3. java将list转为树形结构的方法

    目录 1.通过转化成json封装数据 2.通过java8 stream转换 1.通过转化成json封装数据 原始数据如下 [ { "name":"甘肃省", & ...

  4. 下拉加载dropload.js

    使用下拉加载 使用需要引用的css <link rel="stylesheet" href="../dist/dropload.css"> 使用需要 ...

  5. 资料汇总--java开发程序员必备技能

    1.  熟练使用Java语言进行面向对象程序设计(面向对象:继承.多态.抽象): 有良好的编程习惯(阿里开发手册  链接:http://pan.baidu.com/s/1dFEA6cT 密码:kqj4 ...

  6. HTTP报文(面试会问开发时常用的报文头格式)

    (本文的解释是完整的,ajax把很多东西封装了) HTTP有两类报文:请求报文和响应报文. HTTP请求报文 一个HTTP请求报文由请求行(request line).请求头部(header).空行和 ...

  7. 设计模式学习--面向对象的5条设计原则之依赖倒置原则--DIP

    一.DIP简介(DIP--Dependency Inversion Principle): 1.高层模块不应该依赖于低层模块,二者都应该依赖于抽象.2.抽象不应该依赖于细节,细节应该依赖于抽象.   ...

  8. SQL Server数据库状态和文件状态

    数据库状态 (database states) 查询数据库的当前状态 : 1.查询所有数据库的状态 ,通过sys.databases目录视图的state_desc列 user master go se ...

  9. 使用springcloud gateway搭建网关(分流,限流,熔断)

    Spring Cloud Gateway Spring Cloud Gateway 是 Spring Cloud 的一个全新项目,该项目是基于 Spring 5.0,Spring Boot 2.0 和 ...

  10. JVM之---垃圾回收

    JVM通过GC来回收堆和方法区中的内存,GC的基本原理首先会找到程序中不再被使用的对象,然后回收这些对象所占用的内存. 1.收集器 通常采用收集器的方式实现GC,主要的收集器有引用计数收集器和跟踪收集 ...