线程同步就是针对:多个线程操作同一个资源
并发:同一个对象被多个线程同时操作
处理多线程问题时,多个线程访问同一个对象,并且某些线程还想修改这个对象,这时需要线程同步,线程同步其实就是一种等待机制,多个需要同时访问此对象的线程进入这个对象的等待池,等待前面的线程使用完毕,下一个线程继续使用
通常用队列和锁来解决线程同步
很通俗的例子,就是上厕所排队,然后厕所门上上锁,
狂神真是人才,想出这么有趣的例子
每个对象都有一把锁,队列和锁可以保证线程的安全性
为了保证数据在方法之中被访问时的正确性,在访问时加入锁机制(synchronized),当一个线程获得对象的排它锁,独占资源,其他线程必须等待,使用后释放锁即可,可能存在的问题是:
第一:一个线程持有锁会导致其他所有需要此锁的线程挂起
第二:在多线程竞争下,加锁,释放锁会导致比较多的上下文切换和调度时延,引起性能问题
第三:如果一个优先级高的线程等待一个优先级低的线程释放锁,会导致优先级倒置,引起性能问题
好了,今天先到这里,狂神真的很有趣,欢迎大家看他的视频~