悲观锁与乐观锁是针对进程中线程发生抢占的情况。
悲观锁:认为在程序中存在着大量的竞争关系,一旦某个线程抢占成功,资源锁死,不允许其他线程争抢,适用于多进程。
乐观锁:不认为有大量的线程同时争抢一块资源,以版本号为基础进行 *** 作,适用于少量进程。
我们常用的是乐观锁。
区别:1.悲观锁是当线程拿到资源时,就对资源上锁,并在提交后,才释放锁资源,其他线程才能使用资源。
2.乐观锁是当线程拿到资源时,上乐观锁,在提交之前,其他的锁也可以 *** 作这个资源,当有冲突的时候,并发机制会保留前一个提交,打回后一个提交,让后一个线程重新获取资源后,再 *** 作,然后提交。和git上传代码一样,两个线程都不是直接获取资源本身,而是先获取资源的两个copy版本,然后在这两个copy版本上修改。
3.悲观锁和乐观锁在并发量低的时候,性能差不多,但是在并发量高的时候, 乐观锁的性能远远优于悲观锁。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)