2877|3

73

帖子

0

TA的资源

一粒金砂(初级)

楼主
 

如何在EVC下实现微秒级定时 [复制链接]

有人说用这两个函数
QueryPerformanceCounter     
QueryPerformanceFrequency
可以实现微秒级定时,但具体怎么实现呢?
比如说实现10us的延时。。

最新回复

已经实现了,感谢各位! 代码贴出来大家分享: void Delay_n_us(int n){         LARGE_INTEGER litmp;         LONGLONG QPart1,QPart2;         double dfMinus, dfFreq, dfTim;         QueryPerformanceFrequency(&litmp);         dfFreq = (double)litmp.QuadPart;         QueryPerformanceCounter(&litmp);         QPart1 = litmp.QuadPart;         do         {         QueryPerformanceCounter(&litmp);         QPart2=litmp.QuadPart;         dfMinus=(double)(QPart2-QPart1);         dfTim=dfMinus/dfFreq;         }while(dfTim  详情 回复 发表于 2008-2-18 17:15
点赞 关注

回复
举报

93

帖子

0

TA的资源

一粒金砂(初级)

沙发
 
可以啊。google一下
 
 

回复

76

帖子

0

TA的资源

一粒金砂(初级)

板凳
 
大概如下实现:
                          LARGE_INTEGER PerformCounter1;
                          LARGE_INTEGER PerformCounter2;
                          LARGE_INTEGER CounterPerSec;
                          float TimeCost;
                          LONG64 QTime1;
                          LONG64 QTime2;
                          LONG64  TimeUnit;                  

                               
                          QueryPerformanceFrequency(&CounterPerSec);
                          QueryPerformanceCounter(&PerformCounter1);
                          QueryPerformanceCounter(&PerformCounter2);
                          QTime1 = ((LONG64)PerformCounter1.HighPart << 32) + (LONG64)PerformCounter1.LowPart ;
                          QTime2 = ((LONG64)PerformCounter2.HighPart << 32) + (LONG64)PerformCounter2.LowPart ;
                          TimeUnit = CounterPerSec.LowPart ;
                          
                          while(1)
                          {                                 
                                 TimeCost = float(QTime2-QTime1)/float(TimeUnit);
                                 if(TimeCost>=0.00001)            //10us
                                         break;
                                 QueryPerformanceCounter(&PerformCounter2);
                                 QTime2 = ((LONG64)PerformCounter2.HighPart << 32) + (LONG64)PerformCounter2.LowPart ;
                          }
                          
 
 
 

回复

78

帖子

0

TA的资源

一粒金砂(初级)

4
 
已经实现了,感谢各位!
代码贴出来大家分享:
void Delay_n_us(int n){

        LARGE_INTEGER litmp;
        LONGLONG QPart1,QPart2;
        double dfMinus, dfFreq, dfTim;
        QueryPerformanceFrequency(&litmp);
        dfFreq = (double)litmp.QuadPart;
        QueryPerformanceCounter(&litmp);
        QPart1 = litmp.QuadPart;
        do
        {
        QueryPerformanceCounter(&litmp);
        QPart2=litmp.QuadPart;
        dfMinus=(double)(QPart2-QPart1);
        dfTim=dfMinus/dfFreq;
        }while(dfTim<0.000001*n);

}
 
 
 

回复
您需要登录后才可以回帖 登录 | 注册

查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表