⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 timer-darwin.c

📁 自己移植的linux下的流媒体播放器原代码,支持mms协议,支持ftp和http协议.
💻 C
字号:
/* * Precise timer routines using Mach timing * * Copyright (c) 2003-2004, Dan Villiom Podlaski Christiansen * * Permission is hereby granted, free of charge, to any person * obtaining a copy of this software and associated documentation * files (the "Software"), to deal in the Software without * restriction, including without limitation the rights to use, copy, * modify, merge, publish, distribute, sublicense, and/or sell copies * of the Software, and to permit persons to whom the Software is * furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be * included in all copies or substantial portions of the Software. */#include <unistd.h>#include <stdlib.h>#include <time.h>#include <math.h>#include <sys/time.h>#include <mach/mach_time.h>#include "../config.h"#include "../mp_msg.h"#include "timer.h"/* global variables */static double relative_time, startup_time;static double timebase_ratio;const char *timer_name = "Darwin accurate";/* wrapper for MPlayer G1 */int usec_sleep(int usec_delay){  return usleep(usec_delay);}/* current time in microseconds */unsigned int GetTimer(){  return (unsigned int)((mach_absolute_time() * timebase_ratio - startup_time)			* 1e6);}/* current time in milliseconds */unsigned int GetTimerMS(){  return (unsigned int)(GetTimer() / 1000);}/* time spent between now and last call in seconds */float GetRelativeTime(){  double last_time = relative_time;    if (!relative_time)    InitTimer();    relative_time = mach_absolute_time() * timebase_ratio;  return (float)(relative_time-last_time);}/* initialize timer, must be called at least once at start */void InitTimer(){  struct mach_timebase_info timebase;  mach_timebase_info(&timebase);  timebase_ratio = (double)timebase.numer / (double)timebase.denom     * (double)1e-9;      relative_time = startup_time =     (double)(mach_absolute_time() * timebase_ratio);}#if 0#include <stdio.h>int main() {  int i,j, r, c = 200;  long long t = 0;    InitTimer();  for (i = 0; i < c; i++) {    const int delay = rand() / (RAND_MAX / 1e5);    j = GetTimer();#if 1    r = usec_sleep(delay);#else    r = sleep_accurate(delay / 1e6) * 1e6;#endif    j = (GetTimer() - j) - delay;    printf("sleep time:%8i %5i (%i)\n", delay, j, j - r);    t += j - r;  }  fprintf(stderr, "average error:\t%lli\n", t / c);  return 0;}#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -