Timer的使用,请帮我分析原因,谢了!

Snow780311 2004-09-30 09:28:43
我定义了一个类,继承CCJListView,在类的初始化成员函数中SetTimer(1,6000,NULL),
OnTimer中把当前时间写入文件,可我查看时间不是每6秒一条记录,而是每秒有多条记录,
然后我又修改了SetTimer(1,60000,NULL),这次查看文件每秒的记录少了些,但是,不是1分钟一条记录,虽然定时器时间不很精确,但不能查这么多吧。
请帮忙分析,是什么原因呀,先谢谢。
...全文
106 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
快乐鹦鹉 2004-09-30
  • 打赏
  • 举报
回复
看来是你用了多个定时器造成的
快乐鹦鹉 2004-09-30
  • 打赏
  • 举报
回复
看看你的程序中用到了几个定时器
Snow780311 2004-09-30
  • 打赏
  • 举报
回复
问题解决,谢谢各位,我按楼1做的,谢谢了
alon21 2004-09-30
  • 打赏
  • 举报
回复
要不就是你的程序是多线程的?
kugou123 2004-09-30
  • 打赏
  • 举报
回复
可能你的程序在其他的地方,也发送过WM_TIMER消息,导致OnTimer函数被多次调用,你可以跟踪一次试试看,看到底在什么地方被调用过。
Snow780311 2004-09-30
  • 打赏
  • 举报
回复
void CResumedDeviceAlarmView::OnTimer(UINT nIDEvent)
{
// TODO: Add your message handler code here and/or call default
CStdioFile f( "MapFile.txt",
CFile::modeCreate | CFile::modeWrite | CFile::typeText |CFile::modeNoTruncate);
CString log;
CTime tm = CTime::GetCurrentTime();
log.Format("SetTime:%s\r\n",
tm.Format("%Y-%m-%d %H:%M:%S"));
f.SeekToEnd();
f.WriteString(LPCTSTR(log));
f.Close();

}
alon21 2004-09-30
  • 打赏
  • 举报
回复
查找 SetTimer 看看在多少个地方做了设置,怀疑你重复设置了
快乐鹦鹉 2004-09-30
  • 打赏
  • 举报
回复
在OnTimer中加断点调试一下,是否多次进入。还有,看看你的OnTimer函数怎么写的,贴出来看看
DentistryDoctor 2004-09-30
  • 打赏
  • 举报
回复
OnTimer中判断nIDEvent没?
if(nIDEvent==1)
{
...
}
要不就再试其它的ID,比如SetTimer(WM_USER,6000,NULL);因为1可能被CCJListView用了。

16,551

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • AIGC Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧