当前位置: 首页 > 面试题库 >

当一个用户崩溃时共享内存中的互斥体?

洪祺
2023-03-14
问题内容

假设某个进程正在共享内存中创建一个互斥锁并将其锁定,并在互斥锁锁定时转储核心。

现在,在另一个进程中,如何检测互斥已被锁定但未被任何进程拥有?


问题答案:

如果您在Linux或类似系统上工作,请考虑使用命名信号量而不是(我假设是)pthreads互斥量。我认为没有一种方法可以确定pthreads互斥对象的锁定PID,而无需构建自己的注册表并将其放入共享内存中。



 类似资料:
  • 更新崩溃日志:

  • 我正在使用POSIX共享内存和未命名信号量实现客户机服务器。服务器可以同时处理多个客户端。该代码适用于单个客户端,但不适用于多个客户端。POSIX操作是用,

  • 当程序中有共享数据,肯定不想让其陷入条件竞争,或是不变量被破坏。那么,将所有访问共享数据结构的代码都标记为互斥岂不是更好?这样任何一个线程在执行这些代码时,其他任何线程试图访问共享数据结构,就必须等到那一段代码执行结束。于是,一个线程就不可能会看到被破坏的不变量,除非它本身就是修改共享数据的线程。 当访问共享数据前,使用互斥量将相关数据锁住,再当访问结束后,再将数据解锁。线程库需要保证,当一个线程

  • 共享内存是两个或多个进程共享的内存。 但是,为什么我们需要共享内存或其他通信方式呢? 重申一下,每个进程都有自己的地址空间,如果任何进程想要将自己的地址空间的某些信息与其他进程进行通信,那么只能通过IPC(进程间通信)技术进行。 我们已经知道,通信可以在相关或不相关的进程之间进行。 通常,使用管道或命名管道来执行相互关联的进程通信。 可以使用命名管道或通过共享内存和消息队列的常用IPC技术执行无关

  • 我想在Android系统中将大数据从一个进程/应用程序传输到另一个进程/应用程序,但在Java层使用内存文件创建共享内存的方法并不奏效。 然后尝试在android原生中创建共享内存,我在某处阅读了 ashmem_create_regionAPI可以使用。但看起来这个API无法访问或打开。它在libcutils.so. 这是在 Q1.如何在android本机代码中访问此库。 如果无法访问,那么在nd

  • 通过查看shmget()的手动页面,我了解到shmget()调用在内存中分配了#个页面,这些页面可以在进程之间共享。 它是否要创建内核内存页,并将其映射到进程的本地地址空间?还是为该段保留了相同的进程内存页,并将为其他附加进程共享相同的内存页? 调用shmget()时,内核将保留一定数量的段/页。 调用shmat()时,保留的段映射到进程的地址空间/页。 当一个新进程附加到同一段时,前面创建的内核