- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我的一个 friend 对于如何在用户空间级别(在 pthread 库中)处理同步存在分歧。
一个。我认为在 pthread_mutex_lock 期间,线程会主动等待。意思是 linux 调度器启动这个线程,让它执行他的代码,它看起来应该是这样的:
while (mutex_resource->locked);
然后,调度另一个线程,它可能会释放 locked
字段等。因此,这意味着无论线程在做什么,调度程序都会等待线程完成其调度时间,然后再切换到下一个线程。
我的 friend 认为等待线程以某种方式告诉内核“嘿,我睡着了,根本不要等我”。在这种情况下,内核会立即安排下一个线程,而无需等待当前线程完成其调度时间,因为知道该线程正在休眠。
从我在 pthread 的代码中看到的,似乎有循环处理锁。但也许我错过了什么。
在嵌入式系统中,防止内核等待是有意义的。所以他可能是对的(但我希望他不是 :D)。
谢谢!
最佳答案
a. I think that during a
pthread_mutex_lock
, the thread actively waits.
是的,glibc 的 NPTL pthread_mutex_lock
有主动等待(自旋),但是旋转仅用于非常短的时间并且仅用于某些类型的互斥锁。在此数量之后,pthread_mutex_lock
将通过调用 linux syscall futex
进入休眠状态。带有 WAIT 参数。
只有类型为 PTHREAD_MUTEX_ADAPTIVE_NP 的互斥量才会自旋,默认为 PTHREAD_MUTEX_TIMED_NP
(普通互斥量)而不自旋。 Check MAX_ADAPTIVE_COUNT
in __pthread_mutex_lock
sources ).
如果你想做无限旋转(主动等待),使用pthread_spin_lock
函数与 pthread_spinlock_t
类型的锁。
我会考虑你的问题的其余部分,就好像你正在使用 pthread_spin_lock
:
Then, another thread is scheduled which potentially free the locked field, etc. So this means that the scheduler waits for the thread to complete its schedule time before switching to the next one, no matter what the thread is doing.
是的,如果存在对 CPU 核心的争用,您的主动自旋线程可能会阻止其他线程执行,即使另一个线程将解锁您的线程所需的互斥锁(自旋锁)。
但是如果没有争用(没有线程超额订阅),并且线程被安排在不同的核心上(巧合,或者通过使用 sched_setaffinity
或 pthread_setaffinity_np
手动设置 cpu affinity),自旋将使您能够更快地进行,然后使用基于操作系统的 futex。
b. My friend thinks that the waiting thread somehow tells the kernel "Hey, I'm asleep, don't wait for me at all". In this case, the kernel would schedule the next thread right away, without waiting for the current thread to complete...
是的,他是对的。
futex
是操作系统的现代说法,该线程正在等待内存中的某个值(用于打开一些 mutex
);在当前的实现中,futex
也会让我们的线程进入休眠状态。如果内核知道何时唤醒此线程,则不需要唤醒它来进行旋转。它怎么知道的?锁所有者在执行 pthread_mutex_unlock
时,将检查是否有任何其他线程在这个互斥体上休眠。如果有的话,锁所有者将调用 futex
和 FUTEX_WAKE
,告诉操作系统唤醒一些线程,在这个互斥锁上注册为休眠者。
如果线程在操作系统中将自己注册为等待者,则无需自旋。
关于Linux pthread 互斥锁和内核调度程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23908711/
总的来说,我对 Linux 内核和操作系统非常感兴趣。我想知道的是,内核的文件类型或扩展名是什么?它显然没有 .exe 或 .out 扩展名,因为它们用于安装在操作系统上的应用程序。 内核只是一个二进
我需要为 Raspbian Linux 内核添加一个自己的系统调用。现在我在搜索了大约 2 天以找到解决方案后陷入困境。 要加一个系统调用,我基本上是按照大纲来的( http://elinux.org
对于一个学术项目,我希望将源文件 (myfile.c) 添加到 kernel/目录,与exit.c相同的目录和 fork.c .构建系统似乎不会自动获取新文件,因为我在 myfile.c 中定义的函数
浏览器排行榜 浏览器市占率排行榜全球榜 。 浏览器市占率排行榜中国榜 -快科技 。 如果按照浏览器内核来看, Chromium 内核的市场占有率无疑是最大的,一家独大
给定一个进程或线程的任务结构,迭代属于同一进程的所有其他线程的习惯用法是什么? 最佳答案 Linux 不区分进程(任务)和线程。库调用 fork() 和 pthread_create() 使用相同的系
我正在用c(不是linux。完全从头开始)从头开始制作一个内核,但我遇到了一些问题。我有这个代码: #include "timer.h" int ms = 0; void timer_handler(
我正在从头开始制作一个 C 内核,我实际上只是从网站上复制了这段代码,因为我的代码无法工作,所以我很困惑。 void kmain(void) { const char *str = "my f
我不确定,如果我完全理解上述差异,所以我想自己解释一下,你可以打断我,只要我有错:“内核是创建内核线程的初始代码段。内核线程是由内核管理的进程。用户线程是进程的一部分。如果你有一个单线程进程,那么整个
看一下struct file 定义from this code Linux 内核版本 2.6.18。 我正在尝试比较代码中的两个 struct file 变量,并确定它们是否指的是同一个文件。该结构中
我试图在 Linux 启动时使嵌入式设备中的 LED 闪烁。基本上,LED 闪烁表明 Linux 正在启动。为了使 LED 闪烁,我正在做以下事情 在 init/main.c 中创建了一个全局定时器(
我有一些在 FreeBSD 和 Linux 上运行的特定硬件。 我必须做一个用户空间应用程序,它将使用内核/用户空间应用程序之间的共享内存与驱动程序一起工作。我的应用程序对来自用户空间的共享内存进行忙
我在哪里可以找到 linux 内核中相应函数的解释,特别是对于 ICMPv4? 例如:icmp_reply、icmp_send等 感谢您的帮助。 最好的,阿里木 最佳答案 探索 Linux 内核中的
我在 Linux Kernel 3.4 上工作,我有以下代码: /* Proximity sensor calibration values */ unsigned int als_kadc;
我正在阅读“罗伯特·洛夫 (Robert Love) 撰写的 Linux 内核开发第 3 版”,以大致了解 Linux 内核的工作原理..(2.6.2.3) 我对等待队列的工作方式感到困惑,例如这段代
我之前也问过同样的问题,但是我的帖子不知为何被删除了。 无论如何,我正在尝试使用 C++ 并编写一个允许我直接访问内存并向其中写入内容的程序。我听说我需要对内核做一些事情,因为它是连接操作系统和应用程
在尝试了解 Ruby 执行方法时,我找到了这篇关于在 Ruby 中运行命令的五种方法的博文 http://mentalized.net/journal/2010/03/08/5_ways_to_run
是否有 Linux 发行版(Minix 除外)包含良好的源代码文档?或者,是否有一些好的文档来描述一般的 Linux 源代码? 我已经下载了内核源代码,但是(不出所料)我有点不知所措,我想知道是否有一
有谁知道 linux 中的哪个函数或文件包含查找用于 bind() 系统调用的随机端口的算法?我到处寻找,在 Linux 源代码中找不到包含此算法的方法。 谢谢! 最佳答案 这是一段又长又复杂的代码,
前言 首先,对于有科班背景的读者,可以跳过本系列文章。这些文章的主要目的是通过简单易懂的汇总,帮助非科班出身的读者理解底层知识,进一步了解为什么在面试中会涉及这些底层问题。否则,某些概念将始终
CentOS7.2与CentOS6区别及特点 Linux 操作系统的启动首先从 BIOS 开始,接下来进入 boot loader,由 bootloader 载入内核,进行内核初始化。内核初始化的
我是一名优秀的程序员,十分优秀!