假如一个队列(随便什么类型),现在两个线程对这个队列进行一个只读操作,一个只写操作。请问这种情况下还需要锁去同步吗?
读的不用同步,写的线程要再同步,因为可能出现多人同时做写操作。
只读意味着什么?队列只进不出吗?很少见到这样的场景,一般都是一个线程往队列里放,一个线程从队列里取,两个线程都会改变队列。还有能保证读是原子操作吗?比如if(q.size() > 0) q.get(0);就是不安全的,因为两条语句之间q的size可能已经变成了0,假设那个写线程会进行删除操作的话。还有队列是如何实现的也有影响。所以笼统的说一个只读一个只写是没有意义的。
@groovy2007 怪我没描述得够清楚。是这样的,我用的QT的Qqueue, 主线程只有enqueue操作,子线程只有dequeue操作,但我没看过Qqueue的底层源码是怎么实现的,有没有用过size的判断或者遍历器不知道,所以就是想问问这种很经典的单生产者和单消费者还有没有必要上锁同步。
您好,我是有问必答小助手,你的问题已经有小伙伴为您解答了问题,您看下是否解决了您的问题,可以追评进行沟通哦~
如果有您比较满意的答案 / 帮您提供解决思路的答案,可以点击【采纳】按钮,给回答的小伙伴一些鼓励哦~~
ps:问答VIP仅需29元,即可享受5次/月 有问必答服务,了解详情>>>https://vip.csdn.net/askvip?utm_source=1146287632
非常感谢您使用有问必答服务,为了后续更快速的帮您解决问题,现诚邀您参与有问必答体验反馈。您的建议将会运用到我们的产品优化中,希望能得到您的支持与协助!
速戳参与调研>>>https://t.csdnimg.cn/Kf0y