请问一下, Linux 关于进程/线程之间的锁机制的实现,具体代码从哪里看起呢?

2020-08-18 22:39:12 +08:00
 ashiamd

回顾 java 知识的时候,不了解 synchronized 关键字等"锁"行为到底底层 C 或者汇编是如何实现的,从而能够保证多核 CPU 之间互斥访问内存。感觉网上不少文章也只提到 openJDK 里面对应的 C 代码,但是再深入的汇编 or 硬件又是如何协商实现锁总线等操作的,并没有提及(其实提个思路也好,我就想知道到底是什么地方的代码 or 什么机制保证了 CPU 之间能够根据这类"锁"机制去工作)

本人不是 Linux 大佬,也不是从事 C 语言的并发开发的工作。所以对于 Linux 的锁实现不知道从何查起。

自己先通过"Linux 进程锁"、"Linux 线程锁"等关键字查相关信息,然而没有找到满意的。

比如,各种进程 /线程同步互斥,只要是多核 CPU,那就不可避免需要一套 硬件和软件 共同协商实现的锁机制,以确保 CPU 核之间能够互斥访问内存等。但是这些操作系统底层,与 CPU 相关的同步、互斥等操作,需要从哪里查阅呢?

请问有热心网友知道吗?

750 次点击
所在节点    问与答
1 条回复
Jirajine
2020-08-18 22:43:07 +08:00

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/699441

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX