并发干扰
使用多线程开发可以很好地提高代码效率,但是在多线程对同一数据资源的共享中,许多线程需要的同一个数据做读写修改操作,因此必然会存在竞争问题,而且这些问题通常会带来灾难性的后果,我们来看一个例子:
现在有一个多线程的银行账户管理系统,我的账户内有余额 1000 元,现在有两个线程对我的账户进行操作:
线程 A :存入500元
线程 B :取出200元
我们应该知道,在大多服务器操作系统中都采用抢占式调度(线程状态及属性),每个线程只有一个时间片来执行任务,当时间片用完后会立刻暂停运行交由其他线程,然后再重新排队
在这种情况下,线程 A 和线程 B,可能就会产生冲突:
我们会发现,到最后我的账户只剩了800元,完全忽略了存钱的操作,这肯定不行!
锁对象
为解决代码块并发访问干扰,有两种机制: