sorrowfulxiaoliu 2019-11-17 22:39 采纳率: 0%
浏览 84

如何保证临界区的程序被执行?

各位前辈,小弟刚刚入门并发编程,遇到了这样一个问题,代码如下:


void * thread_main(void *arg)
{
    while (true)
    {
        lock();

        //执行代码

        unlock();
    }
}

在并发编程中是否存在这样一种情况(理论上):

比如说while(true)循环进入后就是临界区,而且临界区内代码比较复杂,执行时间长,这样当前线程可能在时间片用完时,正位于临界区中,另一个线程如果要进入临界区,此时处于阻塞状态,操作系统无法给另一个线程分配时间片,所以操作系统继续执行当前线程,下一次时间片用完时极大可能还是在临界区中,这样的话另一个线程始终得不到时间片。

是否存在这种问题呢,望各位前辈指教。

  • 写回答

1条回答 默认 最新

  • weixin_44670774 2024-02-20 15:53
    关注

    会的。
    这里面有锁,第一个线程获取到锁后,在没有执行完之前是不会释放锁的;另一个互斥的线程,只有等他执行完,才可以继续执行。

    如果有这种情况,可以考虑将原问题分解成更多的子问题,并发求解后,将结果汇总。否则,使用多线程执行这种程序还不如直接单线程一直执行。

    评论

报告相同问题?

悬赏问题

  • ¥15 有赏,i卡绘世画不出
  • ¥15 如何用stata画出文献中常见的安慰剂检验图
  • ¥15 c语言链表结构体数据插入
  • ¥40 使用MATLAB解答线性代数问题
  • ¥15 COCOS的问题COCOS的问题
  • ¥15 FPGA-SRIO初始化失败
  • ¥15 MapReduce实现倒排索引失败
  • ¥15 ZABBIX6.0L连接数据库报错,如何解决?(操作系统-centos)
  • ¥15 找一位技术过硬的游戏pj程序员
  • ¥15 matlab生成电测深三层曲线模型代码