- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我将 pthread_cond_timedwait 与单片定时器一起使用。我想问一下我的示例中是否存在问题或原因是什么,有时 pthread_cond_timedwait 等待的时间超过指定的超时时间(示例中为 300 毫秒)。
示例如下:
#include <pthread.h>
#include <iostream>
#include <ctime>
pthread_cond_t cond;
pthread_condattr_t cond_attr;
pthread_mutex_t mutex;
void *thread1(void *attr)
{
struct timespec ts;
clock_gettime(CLOCK_MONOTONIC, &ts);
//fprintf(stderr, "starting timer for %ds, %dms\n", (period/1000), (period % 1000));
auto period = 300;
auto sec = (period / 1000);
auto nsec = (period % 1000) * 1000000;
fprintf(stderr, "[start] ts.sec=%d ts.ns = %d\n", ts.tv_sec, ts.tv_nsec);
if ((ts.tv_nsec + nsec) > 999999999)
{
ts.tv_sec += sec + 1;
ts.tv_nsec = nsec - (1000000000 - ts.tv_nsec);
fprintf(stderr, "[expected end] ts.sec=%d ts.ns = %d\n", ts.tv_sec, ts.tv_nsec);
//fprintf(stderr, "timeout = %dms\n", (sec * 1000) + ((1000000000 - ts_now.tv_nsec + ts.tv_nsec)/1000000));
}
else
{
ts.tv_sec += sec;
ts.tv_nsec += nsec;
fprintf(stderr, "[expected end] ts.sec=%d ts.ns = %d\n", ts.tv_sec, ts.tv_nsec);
//fprintf(stderr, "timeout = %dms\n", (sec * 1000) + ((ts.tv_nsec - ts_now.tv_nsec) / 1000000));
}
while (true)
{
auto ret = pthread_cond_timedwait(&cond, &mutex, &ts);
if (ret == ETIMEDOUT)
{
struct timespec ts2;
clock_gettime(CLOCK_MONOTONIC, &ts2);
fprintf(stderr, "[end] ts.sec=%d ts.ns = %d\n", ts2.tv_sec, ts2.tv_nsec);
auto seconds = ts2.tv_sec - ts.tv_sec;
auto nseconds = ts2.tv_nsec - ts.tv_nsec;
if (nseconds < 0)
{
seconds--;
nseconds = 1000000000 - nseconds;
}
fprintf(stderr, "[end] diff = %dms\n", (seconds * 1000) + (nseconds / 1000000));
break;
}
if (ret != 0)
{
fprintf(stderr, "ret: %m\n");
}
}
return nullptr;
}
int main()
{
pthread_t tid1;
pthread_mutex_init(&mutex, nullptr);
pthread_condattr_init(&cond_attr);
pthread_condattr_setclock(&cond_attr, CLOCK_MONOTONIC);
pthread_cond_init(&cond, &cond_attr);
pthread_create(&tid1, nullptr, thread1, nullptr);
pthread_join(tid1, nullptr);
return 0;
}
编译:
g++ -std=c++11 main.cpp -lpthread
输出:
dev@ pthread $./a.out
[start] ts.sec=58842 ts.ns = 602310036
[expected end]: ts.sec=58842 ts.ns = 902310036
[end] ts.sec=58842 ts.ns = 903171492
[end] diff = 0ms
dev@ pthread $./a.out
[start] ts.sec=58844 ts.ns = 378002207
[expected end]: ts.sec=58844 ts.ns = 678002207
[end] ts.sec=58844 ts.ns = 799322723
[end] diff = 121ms
最佳答案
您正在通过调用 pthread_cond_timedwait()
来调用未定义的行为,而没有锁定关联的互斥量。
POSIX documentation for pthread_cond_timedwait()
状态:
DESCRIPTION
The
pthread_cond_timedwait()
andpthread_cond_wait()
functions shall block on a condition variable. The application shall ensure that these functions are called withmutex
locked by the calling thread; otherwise, an error (forPTHREAD_MUTEX_ERRORCHECK
and robust mutexes) or undefined behavior (for other mutexes) results.
任何时序问题很容易是这种未定义行为的“奇怪”结果。
并且如评论中所述,无法保证错误返回的速度有多快。
关于c++ - 带有单体定时器的 pthread_cond_timedwait 有时超时比预期晚,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59667156/
我对java有点陌生,所以如果我犯了一个简单的错误,请原谅我,但我不确定我哪里出错了,我收到的错误是“预期的.class,预期的标识符,而不是声明, ';'预期的。”我尝试了不同的方法,并从这些方法中
This question already has answers here: chai test array equality doesn't work as expected (3个答案) 3年前
我正在学习 Java(对不起,我的英语很差,这不是我的母语),当我在 Eclipse (JavaSE-1.7) 中在我输入的每个“try”中执行“try-finally” block 时,会出现以下消
我收到两个错误,指出 token 上的语法错误,ConstructorHeaderName expected instead & token “(”上的语法错误,< expected 在线: mTM.
我找不到错误。 Eclipse 给我这个错误。每个 { } 都是匹配的。请帮忙。 Multiple markers at this line - Syntax error on token “)”,
代码: import java.awt.*; import javax.swing.*; import java.awt.event.*; public class DoubleIt extends
我正在用 python(Vs 代码)编写代码,但出现此错误: Expected ")" Pylance 错误发生在:def main() 我试着运行我的 main 并将它打印到我的屏幕上。我用谷歌搜
我正在尝试按照 documentation 中的建议使用异步函数。但我收到此错误 意外的 token ,预期 ( async function getMoviesFromApi() { try
Closed. This question does not meet Stack Overflow guidelines。它当前不接受答案。 想改善这个问题吗?更新问题,以便将其作为on-topic
Closed. This question does not meet Stack Overflow guidelines。它当前不接受答案。 想改善这个问题吗?更新问题,以便将其作为on-topic
第一行包含一个表示数组长度的整数p。第二行包含用空格分隔的整数,这些整数描述数组中的每个元素。第三行打印一个整数,指示负数组的数量。 package asgn3; import java.util.*
好的,我是初学者,我必须修复此 java 表达式语言代码才能在我的系统 (Windchill) 中工作,但看起来我在语法中遗漏了一些内容: LWCNormalizedObject lwc =
我无法编译我的程序! 我想我缺少一个花括号,但我怎么也看不出在哪里! import javax.swing.*; import java.awt.*;
我的 jQuery 代码有问题,我的 Firebug 向我发出警告:需要选择器。 这是代码: $("img[id$='_tick']").each(function() { $(this).c
我的新类(class) Fountainofyouth 遇到了问题。尝试构建整个项目后,调试器显示 warning: extended initializer lists only available
我已经从 Java 转向 CPP,并且正在努力围绕构造构造函数链进行思考,我认为这是我的问题的根源。 我的头文件如下: public: GuidedTour(); GuidedTour(string
鉴于以下 for(var i=0; i< data.cats.length; i++) list += buildCategories(data.cats[i]); jsLint 告诉我 Expect
我有这个 json,但 Visual Studio Code 在标题中给了我警告。 [ { "title": "Book A", "imageUrl": "https:
我正在尝试编写一个有条件地禁用四个特殊成员函数(复制构造、移动构造、复制赋值和移动赋值)的包装类,下面是我用于测试目的的快速草稿: enum class special_member : uint8_
所以我用 F# 编写了一个非常简单的程序,它应该对 1000 以下的所有 3 和 5 的倍数求和: [1..999] |> List.filter (fun x -> x % 3 = 0 || x %
我是一名优秀的程序员,十分优秀!