A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

提示: 作者被禁止或删除 内容自动屏蔽

14 个回复

倒序浏览
这么详细     学习了  辛苦了
回复 使用道具 举报
叼炸了  嘿嘿
回复 使用道具 举报
提示: 作者被禁止或删除 内容自动屏蔽
回复 使用道具 举报
非常详细,幸苦了
回复 使用道具 举报
zimi626 来自手机 高级黑马 2014-4-27 00:50:02
地板
写的真的很好,即便不是黑马出身看了也会有很大的收获!谢谢楼主!
回复 使用道具 举报
wqmsan 中级黑马 2014-5-23 13:12:50
7#
赞一个!!!
回复 使用道具 举报
票过的存在
回复 使用道具 举报
太繁琐了,互联网公司不用穿西装
回复 使用道具 举报
1. 使用clock() 函数                                                

头文件:<time.h>

clock()函数,返回“自程序启动到调用该函数,CPU时钟的计时单元数(clock tick)”

每过1ms,计数值+1
精度:1毫秒
#include <stdio.h>
#include <time.h>

int main()
{
    clock_t start,end; // typedef long clock_t
    start = clock();
    long i= 1000000000L;while(i--){}
    end = clock();

    //#define CLOCKS_PER_SEC ((clock_t)1000)
    double duration =(double)(end-start)/CLOCKS_PER_SEC;
    printf("%f\n",duration); // 4.015

    return 0;
}
2. 使用time() 函数                                                  

头文件:<time.h> 中

clock()返回公元1970.01.01 0:0:0秒算起到现在所经过的秒数。

即Calendar Time,日历时间

精度:1秒
#include <time.h>

int main()
{
    time_t start,end;  // typedef long time_t;
    start = time(NULL); // 等同于 time(&start);
    long i=1000000000L;while(i--){}
    end = time(NULL);

    long duration =end - start;
    printf("%ld\n",duration); // 4

    return 0;
}
3. 使用GetTickCount () 函数
头文件:<windows.h> 中
在精度要求较高的情况下,可以利用GetTickCount()函数,该函数的返回值是  DWORD型,表示以ms为单位的计算机启动后经历的时间间隔(最大49.7天)。在较短的定时中其计时误差为15ms,在较长的定时中其计时误差较低,如果定时时间太长,就好象死机一样,CPU占用率非常高,只能用于要求不高的延时程序中。
精度:1毫秒,短时误差15ms
#include <stdio.h>
#include <windows.h>

int main()
{
    DWORD start,end;//typedef unsigned long DWORD;
    start = GetTickCount();
    long i=1000000000L;while(i--){}
    end = GetTickCount();

    double duration = (double)(end-start)/1000;
    printf("%f\n",duration); // 3.922
    return 0;
}
4. 使用QueryFrequencyCount () 函数
头文件:<windows.h>
高精度计数器
精度:1微秒,误差不超过0.5微妙(精度为1000 000/(cpu主频)微秒)
#include <stdio.h>
#include <windows.h>

int main()
{
    LARGE_INTEGER f;
    QueryPerformanceFrequency(&f);//获取内部高精度计数器的频率

    double dFreq;
    dFreq = (double)f.QuadPart; //获取计数器的频率

    LARGE_INTEGER start,end;
    QueryPerformanceCounter(&start);//获取内部高精度计数器当前的计数值
    long i=1000000000L;while(i--){}
    QueryPerformanceCounter(&end);

    //时间差 = 计数值差/频率(单位s)
    double duration = (double)(end.QuadPart-start.QuadPart)/dFreq;
    printf("%f\n",duration);// 3.969499
    return 0;
}
深圳信盈达嵌入式、单片机、ARM、MIPS、FPGA、Android培训!
免费试听,满意后给您量身定制课程(包学会),快速提高您的技能!
教学特色:名师督学+工程师指导;项目案列解析+实际解决方案!
技术咨询:宋老师 18336308250 0371-86629510  QQ 2905283896
上课地点:郑州中心地址:郑州市金水区文化路85号A时代广场1906
回复 使用道具 举报
面试时一门学问
回复 使用道具 举报
Mr.hu 中级黑马 2014-12-4 14:00:32
12#

非常的详细
回复 使用道具 举报
哎哟 不错哦!!!
回复 使用道具 举报
找工作拼的还是综合实力啊,光有技术还是不行的
回复 使用道具 举报
说得好极了  谢谢楼主分享
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马