- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我需要一个高分辨率计时器,用于我们应用程序的 Linux 构建中的嵌入式分析器。我们的分析器测量的范围小到单个函数,因此它需要优于 25 纳秒的计时器精度。
之前我们的实现使用内联汇编和rdtsc操作直接从CPU查询高频定时器,但是this is problematic和需要频繁的重新校准。
所以我尝试使用 clock_gettime
函数来查询 CLOCK_PROCESS_CPUTIME_ID。文档声称这给了我纳秒级的计时,但我发现单次调用 clock_gettime()
的开销超过 250ns。这使得不可能为 100 纳秒长的事件计时,并且在定时器功能上拥有如此高的开销会严重拖累应用程序性能,扭曲配置文件超出值(value)。 (我们每秒有数十万个分析节点。)
有没有一种调用 clock_gettime()
的方法开销小于 ¼μs? 或者有没有其他方法可以可靠地获取 <25ns 的时间戳计数器高架?还是我坚持使用 rdtsc
?
下面是我用来计时的代码clock_gettime()
。
// calls gettimeofday() to return wall-clock time in seconds:
extern double Get_FloatTime();
enum { TESTRUNS = 1024*1024*4 };
// time the high-frequency timer against the wall clock
{
double fa = Get_FloatTime();
timespec spec;
clock_getres( CLOCK_PROCESS_CPUTIME_ID, &spec );
printf("CLOCK_PROCESS_CPUTIME_ID resolution: %ld sec %ld nano\n",
spec.tv_sec, spec.tv_nsec );
for ( int i = 0 ; i < TESTRUNS ; ++ i )
{
clock_gettime( CLOCK_PROCESS_CPUTIME_ID, &spec );
}
double fb = Get_FloatTime();
printf( "clock_gettime %d iterations : %.6f msec %.3f microsec / call\n",
TESTRUNS, ( fb - fa ) * 1000.0, (( fb - fa ) * 1000000.0) / TESTRUNS );
}
// and so on for CLOCK_MONOTONIC, CLOCK_REALTIME, CLOCK_THREAD_CPUTIME_ID.
结果:
CLOCK_PROCESS_CPUTIME_ID resolution: 0 sec 1 nano
clock_gettime 8388608 iterations : 3115.784947 msec 0.371 microsec / call
CLOCK_MONOTONIC resolution: 0 sec 1 nano
clock_gettime 8388608 iterations : 2505.122119 msec 0.299 microsec / call
CLOCK_REALTIME resolution: 0 sec 1 nano
clock_gettime 8388608 iterations : 2456.186031 msec 0.293 microsec / call
CLOCK_THREAD_CPUTIME_ID resolution: 0 sec 1 nano
clock_gettime 8388608 iterations : 2956.633930 msec 0.352 microsec / call
这是在标准的 Ubuntu 内核上。该应用程序是 Windows 应用程序的端口(我们的 rdtsc 内联程序集在其中运行良好)。
x86-64 GCC 是否有一些与 __rdtsc() 的内在等价物,所以我至少可以避免内联汇编?
最佳答案
没有。您必须使用特定于平台的代码来执行此操作。在 x86 和 x86-64 上,您可以使用“rdtsc”来读取 Time Stamp Counter .
只需移植您正在使用的 rdtsc 程序集即可。
__inline__ uint64_t rdtsc(void) {
uint32_t lo, hi;
__asm__ __volatile__ ( // serialize
"xorl %%eax,%%eax \n cpuid"
::: "%rax", "%rbx", "%rcx", "%rdx");
/* We cannot use "=A", since this would use %rax on x86_64 and return only the lower 32bits of the TSC */
__asm__ __volatile__ ("rdtsc" : "=a" (lo), "=d" (hi));
return (uint64_t)hi << 32 | lo;
}
关于linux - clock_gettime() 是否适合亚微秒计时?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7935518/
我在将 Firebase 调用函数的返回值分配给全局变量时遇到问题。这是我的功能: function getThePushNameById( path , id ){ path.once(
我正在尝试使用 javascript 创建倒计时。我从 here 得到了一些代码并略作修改。 var c=10, t; function timedCount() { document.getE
我想使用java脚本计算点击两个按钮之间的时间差 最佳答案 这里有一个提示 - 使用: var t = Date.now(); 以毫秒分辨率获取当前时间(自 1970 年 1 月 1 日 00:00:
我试图在单击按钮时显示时钟,但并调用设置超时事件来连续显示当前时间。但每当我单击按钮时,它只会鞋一次。如果我在一段时间后单击,那么它也可以工作,但不会显示连续变化的时间。 脚本 function sh
我有一种情况,在模型的 afterSave 中回调,我正在尝试从远程关联访问数据(这是一个具有非常不稳定的关联链接的遗留数据模型)。我发现的是,在回调中我可以对模型执行查找调用,但如果我此时退出,则记
我这里有这段代码,它从数据库中获取一些运动统计数据,并对其进行更新 - 我正试图在检测到变化时发出警报(#scorealert div)。如果只有一个分数发生了变化,这就可以正常工作。当有多个更改时,
我正在制作一个测验应用程序,我想在其中显示用户在玩游戏时所用的时间。它应该采用 HH:MM:SS 格式,从 00:00:00 开始,直到他选择答案。当用户每秒播放时,计时器应该每秒更新一次。另外,我想
我想知道在 Postgres 中执行查询所需的时间,我看到很多建议使用\timing 的响应,但我是 Postgres 的新手,我不知道如何使用它,谁能帮忙 提前谢谢你 最佳答案 您只能将 \timi
作为我大学论文的一部分,我试图测试几种不同类型的数字输入键盘界面的可用性。为此,我需要记录参与者按下的每个按键以及每个按键的时间。仅仅记录他们在表单上提交的内容是不够的,因为我需要监控他们看到并纠正了
我需要在我的网站上制作一些简短的“新闻快讯”...淡入和淡出一些 `s 并需要它们循环... 到目前为止我有这样的东西: $('.text01').hide().fadeIn('slow').dela
我希望有人能帮我解决这个问题。我想测量排序算法。这是我目前的做法: M = 1000 # number of executions N = [1000, 2000, 4000, 16000] # si
我的项目有个小问题:我在我的程序中使用 C++ chrono 库来处理时间。但是当我在调试计时时钟继续运行时到达断点并且当我继续程序时,与计时器一起工作的东西中有疯狂的值。 现在我的问题:是否有库或方
我正在开发一个 C++ 应用程序,它需要精确到毫秒级的详细计时信息。 我们打算使用标准 time() 收集精确到秒的时间在 中发挥作用.我们还想收集自 time() 给出的最后一秒以来经过的毫秒数。
我试图在敲击之间保持节奏。但是,我随机获得巨大的值(value),我不确定为什么。 @implementation GameScene { CFTimeInterval previousFram
我正在通过几个操作解析一个文件,我想测量执行这些操作所花费的时间。 执行此操作并打印时间的最佳方法是什么? 最佳答案 更新:如果您不反对使用外部库并且您使用的是 JDK 5+,Google Guava
我想收集与网络请求的每个阶段所花费的时间相关的统计信息。 httplib 提供: def run(self): conn = httplib.HTTPConnection('www.examp
我正在制作一款 Android 游戏,其中一些图形元素移动速度很快。我打算使用 Canvas,但担心 onDraw 方法会以不规则的间隔调用,从而使快速元素以不规则的速度移动。有没有办法确保定期调用
我正在制作一个按时间间隔执行的应用程序。更新之间我可以等待的绝对最长时间是30秒,介于0和0之间的任何值都是可以接受的,但是我希望15秒是一个很好的衡量标准。但是,它并不像听起来那样容易。我尝试了4种
我的桌面应用程序有一个恼人的问题,我无法弄清楚。我已将问题隔离到以下示例中。我正在尝试做什么...... 我有一个jframe和5个jpanels,每个面板都有不同的图片。启动后,用户将看到面板 A,
是否有一种标准的方法来记录 Quartz 执行任务所花费的时间?我也对基于 Spring 的解决方案持开放态度,因为我正在使用两者。 最佳答案 您可以使用通用计时库,例如 ERMA .它与 sprin
我是一名优秀的程序员,十分优秀!