• iOS中定时器NSTimer的开启与关闭


    调用一次计时器方法:

    1. myTimer = [NSTimer scheduledTimerWithTimeInterval:1.5 target:self selector:@selector(scrollTimer) userInfo:nil repeats:NO];  
    2. //不重复,只调用一次。timer运行一次就会自动停止运行  

    重复调用计时器方法:

    1. timer =  [NSTimer scheduledTimerWithTimeInterval:1.0 target:self selector:@selector(function:) userInfo:nil repeats:YES];  
    2. //每1秒运行一次function方法。  

    注意:将计数器的repeats设置为YES的时候,self的引用计数会加1。因此可能会导致self(即viewController)不能release,所以,必须在viewWillAppear的时候,将计数器timer停止,否则可能会导致内存泄露。

    停止timer的运行,但这个是永久的停止:(注意:停止后,一定要将timer赋空,否则还是没有释放。不信?你自己试试~)

    1. //取消定时器  
    2. [timer invalidate];  
    3. timer = nil;   

    要想实现:先停止,然后再某种情况下再次开启运行timer,可以使用下面的方法:

    首先关闭定时器不能使用上面的方法,应该使用下面的方法: 

    1. //关闭定时器  
    2. [myTimer setFireDate:[NSDate distantFuture]];  

    然后就可以使用下面的方法再此开启这个timer了: 

    1. //开启定时器  
    2. [myTimer setFireDate:[NSDate distantPast]];  

     例子:比如,在页面消失的时候关闭定时器,然后等页面再次打开的时候,又开启定时器。

    (主要是为了防止它在后台运行,暂用CPU)可以使用下面的代码实现:

       //页面将要进入前台,开启定时器  

    1. -(void)viewWillAppear:(BOOL)animated  
    2. {  
    3.     //开启定时器  
    4.     [scrollView.myTimer setFireDate:[NSDate distantPast]];  
    5. }  
    6.   
    7. //页面消失,进入后台不显示该页面,关闭定时器  
    8. -(void)viewDidDisappear:(BOOL)animated  
    9. {  
    10.     //关闭定时器  
    11.     [scrollView.myTimer setFireDate:[NSDate distantFuture]];  
    12. }  
  • 相关阅读:
    webpack学习_管理输出(管理资源插件)
    vue路由
    vue动态组件,组件缓存
    vue组件间传参
    模块化
    安装Vue脚手架,创建Vue项目
    Vue常用指令
    VUE概述
    小程序调用微信支付接口
    Android音视频开发之-WebRTC技术实践
  • 原文地址:https://www.cnblogs.com/ChouDanDan/p/5070707.html
Copyright © 2020-2023  润新知