库调多了,都忘了最基础的概念 《锁与线程 2 终结篇》

简介: 库调多了,都忘了最基础的概念 《锁与线程 2 终结篇》

🍁 作者:知识浅谈,CSDN博客专家,阿里云签约博主,InfoQ签约博主,华为云云享专家

📌 擅长领域:全栈工程师、爬虫、ACM算法

💒 公众号:知识浅谈

🔥 联系方式vx:zsqtcc

🤞拿下,拿下🤞

温馨提醒:这篇文章无害,请放松阅读

🎈lock、tryLock、lockInterruptibly有什么区别?

lock:获取不到就一直阻塞,直到获取锁

  • 当锁没有被其他线程获取,则计数器记为1,并返回true
  • 当锁本来就是自身含有,则将计数器加1,并返回true
  • 当锁被其他线程持有的时候,则处于阻塞状态,并且在获取到锁后,将保持计数设置为1
    tryLock:获取不到就返回
  • 当锁没有被其他线程获取的时候,并把计数器置为1,则就返回true
  • 当锁本来就是自身含有,则将计数器加1,并返回true
  • 当锁被其他线程持有的时候,返回false
    lockInterruptibly:
  • 当锁没有被其他线程获取的时候,并把计数器置为1,则就返回true
  • 当锁本来就是自身含有,则将计数器加1,并返回true
  • 如果没有可用锁会一直等待直到获取锁,但和 lock 方法不同,lockInterruptibly 方法在等待获取时,如果遇到线程中断会放弃获取锁。

🎈volatile 有什么用?

  1. 保证可见性
    底层有一个汇编编码lock,使得volatile修饰的变量能够同步到主内存中,通过MESI缓存一致性协议使其他的线程中的变量的副本失效,去主内存读取新值。
  2. 保证有序性
    底层为了优化可能会进行指令重排序,volatile主要是通过读写屏障来达到防止指令重排序的目的。

🎈为什么要用读写锁?它有什么优点?

读写锁:分别对读和写加不同的锁,读锁可以和其他读锁共存,就是对同一个资源可以加多个读锁,但是读锁和写锁不能加到一个资源上,也就是加完读锁之后,不能再见写锁。

同理,加完写锁之后不能再加读锁和写锁。

优点:

  1. 多个读锁可以同时执行,所以提高了程序执行性能。
  2. 因为读写锁是互斥的,所以不会读到临时的值。

🎈公平锁和非公平锁有什么区别?

公平锁:在唤醒阻塞的线程的时候,按顺序唤醒阻塞的线程,所以是公平的。也可以这么理解,多个线程获取锁,直接放入阻塞队列。

非公平锁:唤醒阻塞老线程,但是不排除会有新线程抢占,也可以这么理解,多个线程获取锁,获取不到,再放入阻塞队列。

针对synchronized:这个队列是entryset中阻塞的线程

针对ReentrantLock,这个队列是AQS队列。

🍚总结

不肝了不肝了,锁与线程篇就到这了,希望有所帮助。

相关文章
|
1月前
|
安全 Java 编译器
线程安全问题和锁
本文详细介绍了线程的状态及其转换,包括新建、就绪、等待、超时等待、阻塞和终止状态,并通过示例说明了各状态的特点。接着,文章深入探讨了线程安全问题,分析了多线程环境下变量修改引发的数据异常,并通过使用 `synchronized` 关键字和 `volatile` 解决内存可见性问题。最后,文章讲解了锁的概念,包括同步代码块、同步方法以及 `Lock` 接口,并讨论了死锁现象及其产生的原因与解决方案。
71 10
线程安全问题和锁
|
28天前
|
安全 Java 调度
Java编程时多线程操作单核服务器可以不加锁吗?
Java编程时多线程操作单核服务器可以不加锁吗?
39 2
|
19天前
|
运维 API 计算机视觉
深度解密协程锁、信号量以及线程锁的实现原理
深度解密协程锁、信号量以及线程锁的实现原理
26 1
|
1月前
|
存储 缓存 安全
【Java面试题汇总】多线程、JUC、锁篇(2023版)
线程和进程的区别、CAS的ABA问题、AQS、哪些地方使用了CAS、怎么保证线程安全、线程同步方式、synchronized的用法及原理、Lock、volatile、线程的六个状态、ThreadLocal、线程通信方式、创建方式、两种创建线程池的方法、线程池设置合适的线程数、线程安全的集合?ConcurrentHashMap、JUC
【Java面试题汇总】多线程、JUC、锁篇(2023版)
|
8天前
|
Java 应用服务中间件 测试技术
Java21虚拟线程:我的锁去哪儿了?
【10月更文挑战第8天】
19 0
|
13天前
|
安全 调度 数据安全/隐私保护
iOS线程锁
iOS线程锁
22 0
|
2月前
|
数据采集 存储 安全
如何确保Python Queue的线程和进程安全性:使用锁的技巧
本文探讨了在Python爬虫技术中使用锁来保障Queue(队列)的线程和进程安全性。通过分析`queue.Queue`及`multiprocessing.Queue`的基本线程与进程安全特性,文章指出在特定场景下使用锁的重要性。文中还提供了一个综合示例,该示例利用亿牛云爬虫代理服务、多线程技术和锁机制,实现了高效且安全的网页数据采集流程。示例涵盖了代理IP、User-Agent和Cookie的设置,以及如何使用BeautifulSoup解析HTML内容并将其保存为文档。通过这种方式,不仅提高了数据采集效率,还有效避免了并发环境下的数据竞争问题。
如何确保Python Queue的线程和进程安全性:使用锁的技巧
|
17天前
|
Java API
【多线程】乐观/悲观锁、重量级/轻量级锁、挂起等待/自旋锁、公平/非公锁、可重入/不可重入锁、读写锁
【多线程】乐观/悲观锁、重量级/轻量级锁、挂起等待/自旋锁、公平/非公锁、可重入/不可重入锁、读写锁
23 0
|
17天前
|
安全 Java 程序员
【多线程-从零开始-肆】线程安全、加锁和死锁
【多线程-从零开始-肆】线程安全、加锁和死锁
32 0
|
17天前
|
安全 Linux
Linux线程(十一)线程互斥锁-条件变量详解
Linux线程(十一)线程互斥锁-条件变量详解

相关实验场景

更多