zoukankan      html  css  js  c++  java
  • iOS中定时器NSTimer的开启与关闭

    调用一次计时器方法:

    [cpp] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. myTimer = [NSTimer scheduledTimerWithTimeInterval:1.5 target:self selector:@selector(scrollTimer) userInfo:nil repeats:NO];  
    2. //不重复,只调用一次。timer运行一次就会自动停止运行  

    重复调用计时器方法:

    [cpp] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    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赋空,否则还是没有释放。不信?你自己试试~)

    [csharp] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. //取消定时器  
    2. [timer invalidate];  
    3. timer = nil;  

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

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

    [cpp] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. //关闭定时器  
    2. [myTimer setFireDate:[NSDate distantFuture]];  


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

    [csharp] view plain copy
     
     在CODE上查看代码片派生到我的代码片
    1. //开启定时器  
    2. [myTimer setFireDate:[NSDate distantPast]];  


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

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

    [cpp] view plain copy
     
     在CODE上查看代码片派生到我的代码片
      1. //页面将要进入前台,开启定时器  
      2. -(void)viewWillAppear:(BOOL)animated  
      3. {  
      4.     //开启定时器  
      5.     [scrollView.myTimer setFireDate:[NSDate distantPast]];  
      6. }  
      7.   
      8. //页面消失,进入后台不显示该页面,关闭定时器  
      9. -(void)viewDidDisappear:(BOOL)animated  
      10. {  
      11.     //关闭定时器  
      12.     [scrollView.myTimer setFireDate:[NSDate distantFuture]];  
      13. }  
  • 相关阅读:
    node的http与前端交互示例(入门)
    PC监听鼠标和键盘事件,定时无响应退出
    日常问题记录
    基于node.js的websocket 前后端交互小功能
    基于node.js的websocket上传小功能
    阿里云服务器(Linux)上打开新端口
    云服务器初尝试
    wx小程序知识点(八)
    wx小程序知识点(七)
    点绘,线绘,图绘
  • 原文地址:https://www.cnblogs.com/ChouDanDan/p/5382388.html
Copyright © 2011-2022 走看看