1、lock和synchronize区别
悲观锁: 每次去拿数据的时候都认为别人会修改。所以每次在拿数据的时候都会上锁。这样别人想拿数据就被挡住,直到悲观锁被释放。
乐观锁: 每次去拿数据的时候都认为别人不会修改。所以不会上锁,不会上锁!但是如果想要更新数据,则会在更新前检查在读取至更新这段时间别人有没有修改过这个数据。如果修改过,则重新读取,再次尝试更新,循环上述步骤直到更新成功。
可重入锁: 允许同一个线程多次获取同一把锁。例如递归方法加锁。
公平锁: 先申请的先得到,非常公平
非公平锁: 后申请的线程可能先获取到锁,是随机或者按照其他优先级排序的
2、CyclicBarrier和CountDownLatch区别
CountDownLatch: 是一个同步工具类,用来协调多个线程之间的同步,能够使一个线程在等待另外一些线程完成各自工作之后,再继续执行。
CyclicBarrier: 可以实现一组线程相互等待,当所有线程都到达某个屏障点后再进行后续的操作。