java面试中几个常见概念的对比
1、lock和synchronize区别悲观锁: 每次去拿数据的时候都认为别人会修改。所以每次在拿数据的时候都会上锁。这样别人想拿数据就被挡住,直到悲观锁被释放。乐观锁: 每次去拿数据的时候都认为别人不会修改。所以不会上锁,不会上锁!但是如果想要更新数据,则会在更新前检查在读取至更新这段时间别人有没有修改过这个数据。如果修改过,则重新读取,再次尝试更新,循环上述步骤直到更新成功。可重入锁: 允许同一个线程多次获取同一把锁。例如递归方法加锁。公平锁: 先申请的先得到,非常公平非公平锁: 后申请的线






