并发编程带来的风险
最近看了一下《Java并发编程实战》这本书,收获很大。写几篇文章记录下,以便以后参阅;
首先,并发编程在提高资源利用率和优化用户体验的同时,也会带了一些副作用或者是风险:
1:安全性问题
线程安全性问题,多线程共享相同的内存空间,线程可能会修改其他线程正在使用的数据;并且线程的执行顺序不可预测,可能造成数据的不一致性
2:活跃性问题
线程可能无法继续执行;比如线程A等待线程B释放其持有的资源,线程B等待线程A释放其持有的资源;
死锁、活锁、饥饿等
3:性能问题
线程调度器挂起当前活跃线程去运行另一个线程,会频繁出现上下文切换,这会带来一定系统开销;线程过多,CPU更多的时间消耗在线程调度上而非线程运行上;
多线程共享数据时必须使用同步机制,这会抑制某些编译器的优化策略,使内存缓冲区数据无效,也带来了额外的性能开销;
如何解决好这三个方面的问题,是并发编程的关键;
下面的文章也是围绕这个主线进行的。《Java并发编程实战》这本书其实也是讲了如何解决这三个问题的,其中穿插介绍了很多java的并发相关的基本类库