- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在编写一个关于信号量和 fork 的读者/作者问题的实现(这是必需的,而不是不幸的 pthreads)。
这是读者的偏好,基本上是用户指定读者/作者的数量,并且程序 fork 出每个读者/作者所请求的数量。编写者选择一个随机数,将其写入关键部分,并将其报告给控制台。读者只需报告当前的数字即可。
我使用信号量来管理它,出于某种原因,一旦一个进程获得关键部分,它就会迭代所有预定数量的循环,然后才允许下一个进程访问它。我觉得这可能与我在 main 中的 fork()-ing 循环有关,尽管我不确定。
编辑:抱歉,如果我的问题不完全清楚;下面的输出显示了每个进程(读取器 1、写入器 1 等),每个进程连续两次访问临界区(如果我将迭代增加到 10,则访问次数将是 10 倍),这不是我想要的。它应该有一个更随机的输出(每个进程访问它一次然后将其传递)。我不明白为什么每个进程都能够像现在这样阻止访问。
下面是代码:
#include <stdlib.h>
#include <stdio.h>
#include <sys/mman.h>
#include "asm/unistd.h"
#include <semaphore.h>
#define ITERATION 2
int *readCount, *crit_sec;
sem_t wrt, mutex, *s1, *s2;
void writer (int numWriter) {
sem_wait(&wrt);
*crit_sec = rand() % 100 + 1;
printf("Writer %d - Wrote: %d\n", numWriter, *crit_sec);
sem_post(&wrt);
return;
}
void reader (int numReader) {
sem_wait(&mutex);
*readCount++;
if (*readCount == 1) sem_wait(&wrt);
sem_post(&mutex);
printf("Reader %d - Read: %d\n", numReader, *crit_sec);
sem_wait(&mutex);
*readCount--;
if (*readCount==0) sem_post(&wrt);
sem_post(&mutex);
return;
}
int main (int argv, char **argc) {
int numRead, numWrite;
void *ptr1 = mmap(NULL, 2*sizeof(int), PROT_READ | PROT_WRITE, MAP_SHARED | MAP_ANONYMOUS, 0, 0);
void *ptr2 = mmap(NULL, 2*sizeof(sem_t), PROT_READ | PROT_WRITE, MAP_SHARED | MAP_ANONYMOUS, 0, 0);
crit_sec=ptr1, readCount=ptr1+1;
*crit_sec=0, *readCount=0;
s1=ptr2, s2=ptr2+1;
*s1=mutex, *s2=wrt;
sem_init(&mutex,1,1);
sem_init(&wrt,1,1);
if (argv !=3) {
printf("Incorrect usage - must use: ./ReadersWriters [# readers] [# writers]\n");
return 0;
}
if (sscanf (argc[1], "%i", &numRead)!=1|| sscanf (argc[2], "%i", &numWrite)!=1) {
printf("Incorrect usage - must use: ./ReadersWriters [# readers] [# writers]\n");
return 0;
}
int rcnt = 0;
while (rcnt++ < numRead) {
if (fork()==0) {
int i=0;
for(;i<ITERATION;i++) reader(rcnt);
return;
}
}
int wcnt = 0;
while (wcnt++ < numWrite) {
if (fork()==0) {
int j=0;
for (;j<ITERATION;j++) writer(wcnt);
return;
}
}
return 0;
}
这是一个示例输出(尽管处理顺序可能不同):
Reader 1 - Read: 0
Reader 1 - Read: 0
Writer 1 - Wrote: 84
Writer 1 - Wrote: 87
Reader 2 - Read: 87
Reader 2 - Read: 87
Writer 2 - Wrote: 84
Writer 2 - Wrote: 87
感谢您的帮助!
最佳答案
Sorry, what I mean is that I don't want each process to control the critical section multiple iterations in a row without handing it off.
如果一个线程调用 e,调度程序没有义务切换到另一个线程。 G。 sem_post()
,尤其是不使用标准调度策略 SCHED_OTHER
(请参阅 man sched_setscheduler
)。也就是说,使用 #define ITERATION 5
我有时会得到 e。例如:
Reader 1 - Read: 0
Reader 2 - Read: 0
Reader 1 - Read: 0
Reader 1 - Read: 0
Reader 1 - Read: 0
Reader 2 - Read: 0
Reader 1 - Read: 0
Reader 2 - Read: 0
Reader 2 - Read: 84
Reader 2 - Read: 84
Writer 1 - Wrote: 84
Writer 1 - Wrote: 87
Writer 2 - Wrote: 84
Writer 2 - Wrote: 87
Writer 2 - Wrote: 78
Writer 1 - Wrote: 78
Writer 2 - Wrote: 16
Writer 1 - Wrote: 16
Writer 2 - Wrote: 94
Writer 1 - Wrote: 94
关于C - 读取器/写入器(并发): Forking & Semaphores Output,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20183564/
我正在用 C 语言实现一个带有输入和输出重定向的 shell。我可以成功进行输入重定向,但输出重定向不起作用。例如,如果我执行 ls > out.txt,则 out.txt 包含文本“out.txt”
我正在处理创建 AWS API 网关。我正在尝试创建 CloudWatch Log 组并将其命名 API-Gateway-Execution-Logs_${restApiId}/${stageName
我正在修改原作者使用数组构建网页的一些代码: $output[]=$stuff_from_database; $output[]='more stuff'; // etc echo join(
我只想知道它们之间的区别: sort < output 和 sort output 在 Linux 中。它是如何工作的? 最佳答案 这已经在 unix.stackexchange 上讨论过:Perfo
我正在生成外部控制台应用程序并使用异步输出重定向。 as shown in this SO post 我的问题是,在我收到 OutputDataReceived 事件通知之前,生成的进程似乎需要产生一
在 Udemy 上开设类(class)时,我们一直允许使用组件类中的 @Input() 装饰器向组件传递数据。 在阅读 ngBook-2 时,我发现还有另一种方法,即在 @Component 装饰器中
考虑一个 Linux 服务器,它在您的用户的 .bash_profile 中有以下行: echo "Hello world" 因此,每次您通过 ssh 进入它时,您都会看到 Hello world 现
public static void main(String[] args) { String input = new String(JOptionPane.showInputDialog("
我正在使用 MSVS 2008 中的 FFTW3 库对某些数据执行 r2c DFT (n=128)。我已经发现只使用了真实数据 DFT 输出的前半部分……如果我查看我的输出,这似乎是正确的: 0-64
我制作了一个 C 程序,可以从二进制文件中打印出很多值。我相信程序完成它的功能并在它实际显示它吐出的值之前结束。因此,结果我得到了一个可爱的 RUN SUCCESSFUL(总时间:198ms) 突然出
在 hadoop 作业计数器中,“映射输出具体化字节”与“映射输出字节”之间有什么区别?当我禁用映射输出压缩时我没有看到前者所以我猜它是真正的输出字节(压缩)而后者是未压缩的字节? 最佳答案 我认为你
有很多 Stack Overflow 文章与此相关,但没有直接的答案。 这条命令会输出一堆单词 OutputVariable.exe %FILEPATH% 输出: Mary had a little
互联网上的许多文章都使用“标准输入/输出/错误流”术语好像每个术语都与使用的“标准输入/输出/错误设备”术语具有相同的含义在其他文章上。例如,很多文章说标准输出流默认是监视器,但可以重定向到文件、打印
我在 Keras 中使用一些 tensorflow 函数(reduce_sum 和 l2_normalize)在最后一层构建模型时遇到了这个问题。我已经搜索了一个解决方案,但所有这些都与“Keras
我有来自 API 的自定义输出,我想将其格式化为带有一些颜色值的字符串。 最佳答案 输出 channel 可以用 TmLanguage grammar 着色. Output Colorizer扩展扩展
我正在寻找一种方法来查看虚拟机创建过程中发生的情况,因为我使用复杂的集群配置并测试其是否正常工作,我需要能够查看输出,在某些情况下我是不是因为敏感。这与运行remote-exec选项有关 module
当谷歌搜索此错误时没有看到任何相关结果,所以我想发布它。 stack build Building all executables for `gitchapter' once. After a suc
假设module_a里面有register_a,它需要链接到module_b。 register_a 是否应该单独声明并分配给 module_a 的输出: reg register_a; assign
我正在寻找一种方法来查看虚拟机创建过程中发生的情况,因为我使用复杂的集群配置并测试其是否正常工作,我需要能够查看输出,在某些情况下我是不是因为敏感。这与运行remote-exec选项有关 module
输入文件如下 eno::ename::dept::sal 101::emp1::comp1::2800000 201::emp2::comp2::2800000 301::emp3::comp3::3
我是一名优秀的程序员,十分优秀!