基于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. 面试:http协议

    转自:http://www.cnblogs.com/ranyonsue/p/5984001.html#undefined HTTP简介 HTTP协议是Hyper Text Transfer Proto ...

  2. 我在项目中运用 IOC(依赖注入)--实战篇

    上一篇<我在项目中运用 IOC(依赖注入)--入门篇>只是简单的使用 IOC.实际项目使用 IOC 的情景复杂多了,比如说,构造函数有多个参数,有多个类继承同一个接口... Unity都有 ...

  3. 网络编程: 基于TCP协议的socket, 实现一对一, 一对多通信

    TCP协议  面向连接 可靠的 面向字节流形式的 tcp是基于链接的,必须先启动服务端,然后再启动客户端去链接服务端 TCP协议编码流程: 服务器端:                 客户端 实例化对 ...

  4. CSS中vertical-align的默认值baseline的理解

    写在前面的话 在学校业余学习了一个月的CSS,人生中第一篇博客就献给CSS了,欢迎大家指正文章中不正确的地方,在此感谢.在尝试开始写博客的时候查了好多资料,原本以为写自己熟悉的知识的博客很容易,没想到 ...

  5. JavaWeb学习总结(十):Session简单使用

    一.Session简单介绍 在WEB开发中,服务器可以为每个用户浏览器创建一个会话对象(session对象),注意:一个浏览器独占一个session对象(默认情况下).因此,在需要保存用户数据时,服务 ...

  6. 【代码笔记】iOS-iphone开发之获取系统字体

    代码: - (void)viewDidLoad { [super viewDidLoad]; // Do any additional setup after loading the view. NS ...

  7. 浅谈 JavaScript 中常用数据及其类型转换

    在 JavaScript 中有一些 value 会经常碰到: [] (空数组).{} (空对象).'' (空字符串).undefined.null.0.NaN.Infinite 也会经常碰到数据类型转 ...

  8. 使用WebDAV实现Office文档在线编辑

    Office的文档处理能力是非常强大的,但是它是本地资源,在Office Web App尚未成熟前,仍需要使用本地能力来进行文档编辑,可是现代的系统的主流却是B/S,所以在B/S中调用本地的Offic ...

  9. 【node】fs模块,文件和目录的操作

    检查文件是否存在,查询文件信息 fs.stat() fs.stat('./server.js', function (err, stat) { if (stat && stat.isF ...

  10. 网络I/O模型--03非阻塞模式(ServerSocket与Socket的超时处理)--解除accept()、 read()方法阻塞

    对于阻塞方式的一种改进是在应用程序层面上将 “一直等待 ”的状态主动打开: 这种模式下,应用程序的线程不再一直等待操作系统的 I/O状态,而是在等待一段时间后就解除阻塞.如果没有得到想要的结果,则再次 ...