重庆分公司,新征程启航

为企业提供网站建设、域名注册、服务器等服务

c语言定时器函数程序 c语言定时器函数程序是什么

怎么用C语言编定时器?

Windows提供了定时器,帮助我们编写定期发送消息的程序。定时器一般通过一下两中方式通知应用程序间隔时间已到。

在白朗等地区,都构建了全面的区域性战略布局,加强发展的系统性、市场前瞻性、产品创新能力,以专注、极致的服务理念,为客户提供网站制作、成都做网站 网站设计制作按需策划设计,公司网站建设,企业网站建设,品牌网站建设,全网营销推广,成都外贸网站制作,白朗网站建设费用合理。

⑴ 给指定窗口发送WM_TIMER消息,也就是下面的给出在窗口类中使用的方法。

⑵ 调用一个应用程序定义的回调函数,也就是在非窗口类中使用方法。

4.1 在窗口类中使用定时器

在窗口类中使用定时器比较简单。假如我们想让这个窗口上放置一个电子钟,这样我们必须每1秒或者0.5秒钟去更新显示显见。按照下面的步骤,就可以完成这个电子钟程序,并且知道如何在窗口类中使用定时器:

首先做在我们新建项目的主窗口上添加一个Label控件,用来显示时间。接着

⑴ 用函数SetTimer设置一个定时器,函数格式如下: UINT SetTimer( UINT nIDEvent,

UINT nElapse,

void (CALLBACK EXPORT* lpfnTimer)(HWND, UINT, UINT, DWORD));

这个函数是CWnd类的一个成员函数,其参数意义如下:

nIDEvent: 为设定的定时器指定的定时器标志值,设置多个定时器的时候,每个定时器的值都不同,消息处理函数就是通过这个参数来判断是哪个定时器的。这里我们设定为1。

nElapse: 指定发送消息的时间间隔,单位是毫秒。这里我们设定为1000,也就是一秒。

lpfnTimer: 指定定时器消息由哪个回调函数来执行,如果为空,WM_TIMER将加入到应用程序的消息队列中,并由CWnd类来处理。这里我们设定为NULL。

最后代码如下:SetTimer(1,1000,NULL);

⑵ 通过Class Wizard给主窗口类添加一个WM_TIMER消息的映射函数,默认为OnTimer(UINT nIDEvent)。

⑶ 然后我们就可以在OnTimer(UINT nIDEvent)的函数实现中添加我们的代码了。参数nIDEvent就是我们先前设定定时器时指定的标志值,在这里我们就可以通过它来区别不同的定时器,而作出不同的处理。添加的代码如下:switch(nIDEvent)

{

case 1:

CTime m_SysTime = CTime::GetCurrentTime();

SetDlgItemText(IDC_STATIC_TIME,m_SysTime.Format("%Y年%m月%d日 %H:%M:%S"));

break;

}

代码中的IDC_STATIC_TIME就是我们先前添加的Label控件的ID。

至此,我们的电子钟的程序就完成了。

4.2 在非窗口类中使用定时器

在非窗口类中使用定时器就要用到前面我们介绍到的所有知识了。因为是无窗口类,所以我们不能使用在窗口类中用消息映射的方法来设置定时器,这时候就必须要用到回调函数。又因为回调函数是具有一定格式的,它的参数不能由我们自己来决定,所以我们没办法利用参数将this传递进去。可是静态成员函数是可以访问静态成员变量的,因此我们可以把this保存在一个静态成员变量中,在静态成员函数中就可以使用该指针,对于只有一个实例的指针,这种方法还是行的通的,由于在一个类中该静态成员变量只有一个拷贝,对于有多个实例的类,我们就不能用区分了。解决的办法就是把定时器标志值作为关键字,类实例的指针作为项,保存在一个静态映射表中,因为是标志值是唯一的,用它就可以快速检索出映射表中对应的该实例的指针,因为是静态的,所以回调函数是可以访问他们的。

首先介绍一下用于设置定时的函数:

UINT SetTimer(

HWND hWnd, // handle of window for timer messages

UINT nIDEvent, // timer identifier

UINT uElapse, // time-out value

TIMERPROC lpTimerFunc // address of timer procedure

);

其中的参数意义如下:

hWnd: 指定与定时器相关联的窗口的句柄。这里我们设为NULL。

nIDEvent: 定时器标志值,如果hWnd参数为NULL,它将会被跳过,所以我们也设定为NULL。

uElapse: 指定发送消息的时间间隔,单位是毫秒。这里我们不指定,用参数传入。

lpTimerFunc: 指定当间隔时间到的时候被统治的函数的地址,也就是这里的回调函数。这个函数的格式必须为以下格式:

VOID CALLBACK TimerProc(

HWND hwnd, // handle of window for timer messages

UINT uMsg, // WM_TIMER message

UINT idEvent, // timer identifier

DWORD dwTime // current system time

);

其中的参数意义如下:

hwnd: 与定时器相关联的窗口的句柄。

uMsg: WM_TIMER消息。

idEvent: 定时器标志值。

deTime: 系统启动后所以经过的时间,单位毫秒。

最后设定定时器的代码为:m_nTimerID = SetTimer(NULL,NULL,nElapse,MyTimerProc);

先通过Class Wizard创建一个非窗口类,选择Generic Class类类型,类名称为CMyTimer,该类的作用是每隔一段时间提醒我们做某件事情,然后用这个类创建三个实例,每个实例以不同的时间间隔提醒我们做不同的事情。

MyTimer.h#include

class CMyTimer;

//用模板类中的映射表类定义一种数据类型

typedef CMap CTimerMap;

class CMyTimer

{

public:

//设置定时器,nElapse表示时间间隔,sz表示要提示的内容

void SetMyTimer(UINT nElapse,CString sz);

//销毁该实例的定时器

void KillMyTimer();

//保存该实例的定时器标志值

UINT m_nTimerID;

//静态数据成员要提示的内容

CString szContent;

//声明静态数据成员,映射表类,用于保存所有的定时器信息

static CTimerMap m_sTimeMap;

//静态成员函数,用于处理定时器的消息

static void CALLBACK MyTimerProc(HWND hwnd,UINT uMsg,UINT idEvent,DWORD dwTime);

CMyTimer();

virtual ~CMyTimer();

};

MyTimer.cpp#include "stdafx.h"

#include "MyTimer.h"

//必须要在外部定义一下静态数据成员

CTimerMap CMyTimer::m_sTimeMap;

CMyTimer::CMyTimer()

{

m_nTimerID = 0;

}

CMyTimer::~CMyTimer()

{

}

void CALLBACK CMyTimer::MyTimerProc(HWND hwnd,UINT uMsg,UINT idEvent,DWORD dwTime)

{

CString sz;

sz.Format("%d号定时器:%s",

idEvent,

m_sTimeMap[idEvent]-szContent);

AfxMessageBox(sz);

}

void CMyTimer::SetMyTimer(UINT nElapse,CString sz)

{

szContent = sz;

m_nTimerID = SetTimer(NULL,NULL,nElapse,MyTimerProc);

m_sTimeMap[m_nTimerID] = this;

}

void CMyTimer::KillMyTimer()

{

KillTimer(NULL,m_nTimerID);

m_sTimeMap.RemoveKey(m_nTimerID);

}

这样就完成了在非窗口类中使用定时器的方法。以上这些代码都在Windwos 2000 Professional 和 Visual C++ 6.0中编译通过。

急急急C语言定时器程序注释

/*****定时器T0*****/

void init() //定时器初始化函数

EA=1; //开总中断

ET0=1; //打开定时器0

TMOD=0x01; //设置计数器工作模式

TH0=0x3c;

TL0=0xb0; //为定时器赋初始值

TR0=1; //允许定时器中断

}

void time() interrupt 1 //中断函数 (在中断中要执行的语句)

{

TH0=0x3c;

TL0=0xb0; //初始值

ee++; //计数位 记录定时器溢出次数

if(ee==10) //判断是否达到预定时间间隔

{

h=~h; // 用户的任务

ee=0; //清除 标志位重新计数

}

}

C语言编程(定时器50ms)

#include“reg52.h”  //头文件,包含各种寄存器定义及函数库

time0()      interrupt 1        using 0

{

TH0=0x3C;TLO=0xB0;

P1_0=~P1_0;

}

main()

{

  TMOD=0x01; TH0=0x3C;TLO=0xB0;

//12MHz下,50ms定时所对应的初值

  EA=1;ET0=1;TRO=1;

  while(1)

  {

    }

}

C语言 timer函数 和time函数

Timer()函数

语法:Timer ( interval {, windowname } )

参数:指定两次触发Timer事件之间的时间间隔,有效值在0到65之间。如果该参数的值指定为0,那么关闭定时器,不再触发指定窗口的Timer事件。windowname:窗口名,指定时间间隔到时要触发哪个窗口的Timer事件。省略该参数时,触发当前窗口的Timer事件返回值Integer。函数执行成功时返回1,发生错误时返回-1。如果任何参数的值为NULL,Timer()函数返回NULL。用法使用Timer()函数可以周期性地触发指定窗口的Timer事件,这样,每当时间间隔过去时,应用程序都可以完成一些周期性的工作,比如绘制简单动画等。将Timer()的interval参数设置为非0值时启动定时器并开始计时;将该函数的interval参数设置为0时关闭定时器,终止计时任务。需要注意的是,在Microsoft Windows系统中,该函数能够计时的最小时间间隔为0.055秒(约1/18秒),如果把interval参数的值设置小于0.055,那么该定时器将每隔0.055秒触发一次窗口的Timer事件。Microsoft Windows 3.x最多只支持系统中同时启动16个定时器。

用法:

启动定时器。

启动定时器就需要使用CWnd类的成员函数SetTimer。CWnd::SetTimer的原型如下:

UINT_PTR SetTimer(

UINT_PTR nIDEvent,

UINT nElapse,

void (CALLBACK* lpfnTimer)(

HWND,

UINT,

UINT_PTR,

DWORD

)

);

参数nIDEvent指定一个非零的定时器ID;参数nElapse指定间隔时间,单位为毫秒;参数lpfnTimer指定一个回调函数的地址,如果该参数为NULL,则WM_TIMER消息被发送到应用程序的消息队列,并被CWnd对象处理。如果此函数成功则返回一个新的定时器的ID,我们可以使用此ID通过KillTimer成员函数来销毁该定时器,如果函数失败则返回0。

通过SetTimer成员函数我们可以看出,处理定时事件可以有两种方式,一种是通过WM_TIMER消息的消息响应函数,一种是通过回调函数。

如果要启动多个定时器就多次调用SetTimer成员函数。另外,在不同的CWnd中可以有ID相同的定时器,并不冲突。

time函数

返回某一特定时间的小数值。如果在输入函数前,单元格的格式为“常规”,则结果将设为日期格式。

函数 TIME 返回的小数值为 0(零)到 0.99999999 之间的数值,代表从 0:00:00 (12:00:00 AM) 到 23:59:59 (11:59:59 P.M.) 之间的时间。

语法:

TIME(hour, minute, second)

TIME 函数语法具有以下参数:

Hour 必需。0(零)到 32767 之间的数值,代表小时。任何大于 23 的数值将除以 24,其余数将视为小时。例如,TIME(27,0,0) = TIME(3,0,0) = .125 或 3:00 AM。

Minute 必需。0 到 32767 之间的数值,代表分钟。任何大于 59 的数值将被转换为小时和分钟。例如,TIME(0,750,0) = TIME(12,30,0) = .520833 或 12:30 PM。

Second 必需。0 到 32767 之间的数值,代表秒。任何大于 59 的数值将被转换为小时、分钟和秒。例如,TIME(0,0,2000) = TIME(0,33,22) = .023148 或 12:33:20 AM。

例子:

?php$t=time();echo($t . "br /");echo(date("D F d Y",$t));?

输出:

1138618081Mon January 30 2006


本文名称:c语言定时器函数程序 c语言定时器函数程序是什么
网页网址:http://cqcxhl.cn/article/ddicghd.html

其他资讯

在线咨询
服务热线
服务热线:028-86922220
TOP