相关疑难解决方法(0)

c ++,usleep()是过时的,Windows/MingW的变通方法?

我已经发现了另一个问题,即Windows/MingW没有为过时的usleep()提供nanosleep()和setitimer()替代方案.但我的目标是修复cppcheck给我的所有警告,包括usleep()样式警告.

那么,是否有一种解决方法可以在使用cygwin或安装大量新依赖项/库的情况下以某种方式避免使用Windows上的usleep()?谢谢.

c++ windows cppcheck usleep

24
推荐指数
6
解决办法
6万
查看次数

如何在Linux中获得最准确的实时周期性中断?

我希望在10的幂的频率下被中断,因此启用/ dev/rtc的中断并不理想.我想在中断之间睡1毫秒或250微秒.

从/ dev/hpet启用定期中断非常有效,但它似乎在某些机器上不起作用.显然我不能在没有HPET的机器上使用它.但我无法让它在一些可以作为时钟源使用的机器上工作.例如,在Core 2 Quad上,当设置为poll时,内核文档中包含的示例程序在HPET_IE_ON处失败.

使用Linux提供的itimer接口而不是直接与硬件设备驱动程序连接会更好.在某些系统上,itimer提供的定期中断随着时间的推移更加稳定.也就是说,由于hpet不能以我想要的频率中断,因此中断开始从挂起时间开始漂移.但我发现有些系统的睡眠时间比使用itimer要长(10+毫秒).

这是一个使用itimer进行中断的测试程序.在某些系统上,它只打印出一个警告,它在目标时间内睡眠约100微秒左右.在其他情况下,它将打印出批次警告,它在目标时间内睡了10+毫秒.用-lrt编译并运行sudo chrt -f 50 [name]

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <error.h>
#include <errno.h>
#include <sys/ioctl.h>
#include <sys/types.h>
#include <sys/time.h>
#include <time.h>
#include <signal.h>
#include <fcntl.h>
#define NS_PER_SECOND 1000000000LL
#define TIMESPEC_TO_NS( aTime ) ( ( NS_PER_SECOND * ( ( long long int ) aTime.tv_sec ) ) \
    + aTime.tv_nsec )

int main()
{
    // Block alarm signal, will be waited on explicitly
    sigset_t lAlarm;
    sigemptyset( &lAlarm );
    sigaddset( &lAlarm, SIGALRM  );
    sigprocmask( …
Run Code Online (Sandbox Code Playgroud)

linux real-time timer

7
推荐指数
2
解决办法
1万
查看次数

标签 统计

c++ ×1

cppcheck ×1

linux ×1

real-time ×1

timer ×1

usleep ×1

windows ×1