最近在重构项目代码时,发现两个线程同时访问一个加锁的std::list队列时,会出现恶性竞争锁的现象。

具体现象是A线程总是拿不到锁,B线程抢占几次后,A才抢占到。

由于是重构项目,也无法通过回滚代码来解决。

最终定位问题是,重构时对std::list队列单独封装了一个类导致的。单独封装一个类,那么每次push pop时都会多了一层函数堆栈。

删除该封装后,问题解决。

由此得出一个结论,对于频繁唤醒的读写线程,执行的操作应该尽量简单直接,避免冗余,避免进行过度的封装

相关文章:

  • 2022-12-23
  • 2021-11-21
  • 2022-12-23
  • 2022-03-02
  • 2021-04-08
  • 2021-08-17
  • 2021-04-26
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2022-12-23
  • 2021-10-25
  • 2022-01-06
  • 2022-01-29
  • 2021-12-17
  • 2022-12-23
相关资源
相似解决方案