条目十二《切勿对slt容器的线性安全性又不切实际的依赖》

条目十二《切勿对slt容器的线性安全性又不切实际的依赖》

这一条目,我想用简短而有力的语句来总结。

stl库是为了照顾大多数情况,而不是某一领域,如果在库层次实现线性安全,很大可能是对性能有所损耗的,这样就得不偿失了,还是让开发者自己按需实现。标准没有在库实现线性安全。一般是厂商实现,可能吧,只能是期望,不一定的。

我们可以期望:

  • 1.stl提供多个线程读是安全的
  • 2.stl提供多个线程对不同的容器做写入操作是安全的。

这些都是期望啊啊啊。

必要的线性安全还是要靠我们自己来控制的。

线性安全一般是使用锁,为了异常安全,会使用RAII(获得资源时即初始化)来保证。在线性同步时需要注意临界区的大小,粒度太大,会造成并发量低,效率低。粒度太小,会造成cpu切换过快过多,造成cpu利用率低。

posted @ 2019-01-12 00:17  那一抹风  阅读(238)  评论(0编辑  收藏  举报