当前位置:首页 > 四级网络工程师 > [1] > 正文内容

[1][34][多选]在有 N 个缓冲区的生产者 - 消费者问题中,下列叙述中哪些是错误的

[1]11个月前 (01-18)
producer()
{
    int item;
    while (TRUE) {
        item = produce_item();
        P(empty);
        P(mutex);
        insert_item(item);
        V(mutex);
        V(full);
    }
}

consumer()
{
    int item;
    while (TRUE) {
        P(full);
        P(mutex);
        item = remove_item();
        V(mutex);
        V(empty);
        consume_item(item);
    }
}

信号量 empty 的初始值为 N

信号量 full 的初始值为 0

信号量 mutex 的初始值为 0

P(full)和 P(mutex)两条语句可以颠倒顺序

V(full)和 V(mutex)两条语句可以颠倒顺序


答案


信号量 mutex 的初始值为 0

P(full)和 P(mutex)两条语句可以颠倒顺序


解析


empty 信号量是表示的是空缓冲区数目,这里为 N,所以其初始值为 N;full 信号量是表示的是满缓冲区数目,这里为 0,即其初始值为 0;mutex 信号量是用于实现互斥访问,初始值为 1。P(full和 P(mutex两条语句若颠倒顺序,可能导致死锁;V(full和 V(mutex两条语句若颠倒顺序,可能导致错误。故本题答案选 CD。涉及考点为第 4 章 并发与同步。


转载请注明出处。

本文链接:http://www.pythonopen.com/?id=1754

相关文章

[1][10][单选]下列各种情况中,一定不会引起进程调度的操作是

一个进程完成工作后被撤销一个进程从运行状态变成了阻塞状态或就绪状态一个进程从阻塞状态变成了就绪状态一...

[1][30][单选]假设系统由相同类型的 7 个资源被 3 个进程共享,若要使系统不会死锁,每个进程最多可以申请的资源个数是

1234答案3解析7 个资源全部分给 3 个进程,每个进程可以获取 2 个资源,此外还剩一个资源,因...

[1][33][多选]在抢占式调度系统中,进程从运行状态转换为就绪状态的可能原因是

被调度程序抢占处理机等待某一事件等待的事件已经发生进程创建完成时间片用完答案被调度程序抢占处理机进程...

[1][35][多选]下列关于地址映射的叙述中,哪些是正确的

地址映射过程通常是由硬件完成的地址映射过程中一定要访问页目录和页表地址映射是将虚拟地址转换为物理地址...

[1][37][多选]下列各种选项中,哪些是文件控制块中必须保存的信息

文件名文件大小文件创建时间文件描述符磁盘块起始地址function addCheckboxClick...