关于二进制信号量

本文探讨了二进制信号量在处理多任务共享资源时的重要性。通过一个VxWorks操作系统的示例,展示了如何使用二进制信号量实现任务间的互斥访问,解释了信号量的工作原理和调度机制。在示例中,两个任务交替修改全局变量,体现了信号量在防止数据冲突和保证资源访问顺序中的关键作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天刚看到二进制信号量的问题,有些疑问请教大家:

1,用共享资源时需要用二进制信号量互斥,我的问题是,程序不是顺序执行的嘛,那在一个时间段只有一个程序可以访问共享资源,这个程序完了 ,下个程序才能访问。何必要互斥,难道程序都是并行发生的?

2,一个例子:

#include "vxworks.h"
#include "tasklib.h"
#include "semlib.h"
#include "stdio.h"

#define ITER 10
SEM_ID semBinary;
int global=0;

static void taskOne()
{
int i;
for(i=0;i<ITER;i++)
{
semTake(semBinary,WAIT_FOREVER);
printf("I am taskOne and global =%d ........................./n",++global);
semGive(semBinary);
}
}

static void taskTwo()
{
int i;
semGive(semBinary);/*NOTE 1*/
for(i=0;i<ITER;i++)
{
semTake(semBinary,WAIT_FOREVER);
printf("I am taskTwo and global =%d..................../n",--global);
semGive(semBinary);
}

}

void s3_sem()
{
int taskIdOne,taskIdTwo;
semBinary=semBCreate(SEM_Q_FIFO,SEM_FULL);
semTake(semBinary,WAIT_FOREVER); /*NOTE 2*/

taskIdOne =taskSpawn("t1",90,0x100,2000,(FUNCPTR)taskOne,0,0,0,0,0,0,0,0,0,0);

taskIdTwo =taskSpawn("t2",90,0x100,2000,(FUNCPTR)taskTwo,0,0,0,0,0,0,0,0,0,0);
}

在这个例子中,两个任务竞争修改global的值,运行结果是1,0,1,0,1,0.。。。。。。,1,0

我的问题是:

两个任务为什么会在每个for语句只执行一遍的时候就跳到下一个for里面去,而执行完后又会跳回到for里面继续执行,然后又执行一遍又跳出。

 

 

-------------------------------------------------------------------------------------------------------------------------------------------------------------------


作者:chenlei188 时间:2008-8-17 15:29:35

首先感谢楼上两位的答

根据京东、亚马逊、天猫等平台的商业实践,考虑由一个制造商和一个平台以及一群消费者构成的供应链结构。我们假设消费者总规模为1其中消费者分为两类:一类消费者参合作设计,其比例为x(这类消费者制造商在产品设计中一起付出努力),而另一类消费者不参产品合作设计,其比例为(1-x)(这类消费者不付出努力)。我们认为只有参产品合作设计的消费者和制造商付出努力,而不参产品合作设计的消费者不付出努力。因此,参产品合作设计的消费者的效用受到制造商的努力、自身的努力以及产品价格的影响;而不参产品合作设计的消费者的效用只受到制造商的努力和产品价格的影响。问题(1): 基于上述的描述请构建一个涉及平台、消费者和制造商三方共同参产品合作设计的博弈模型?平台只提供销售模式而不付出产品设计努力。要求数学模型中需包括制造商和参产品设计的消费者的努力程度,分别给出两类消费者的关于努力程度和产品价格的具体效用函数,制造商和和平台的利润函数,其中决策变量为制造商和消费者的努力程度、产品价格。问题(2):请分别给出零售模式和代售模式下关于上述情形的具体数学模型(包括由效用函数导出的需求函数,利润函数),计算制造商和平台的利润、两类消费者的剩余,并分析平台的最优模式选择(根据阈)。
06-04
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值