库调多了,都忘了最基础的概念 《锁与线程 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队列。

🍚总结

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

相关文章
|
10月前
|
数据采集 Java API
Jsoup库能处理多线程下载吗?
Jsoup库能处理多线程下载吗?
|
3月前
|
负载均衡 算法 安全
基于Reactor模式的高性能网络库之线程池组件设计篇
EventLoopThreadPool 是 Reactor 模式中实现“一个主线程 + 多个工作线程”的关键组件,用于高效管理多个 EventLoop 并在多核 CPU 上分担高并发 I/O 压力。通过封装 Thread 类和 EventLoopThread,实现线程创建、管理和事件循环的调度,形成线程池结构。每个 EventLoopThread 管理一个子线程与对应的 EventLoop(subloop),主线程(base loop)通过负载均衡算法将任务派发至各 subloop,从而提升系统性能与并发处理能力。
186 3
|
13天前
|
设计模式 消息中间件 安全
【JUC】(3)常见的设计模式概念分析与多把锁使用场景!!理解线程状态转换条件!带你深入JUC!!文章全程笔记干货!!
JUC专栏第三篇,带你继续深入JUC! 本篇文章涵盖内容:保护性暂停、生产者与消费者、Park&unPark、线程转换条件、多把锁情况分析、可重入锁、顺序控制 笔记共享!!文章全程干货!
69 1
|
8月前
|
存储 Linux API
【Linux进程概念】—— 操作系统中的“生命体”,计算机里的“多线程”
在计算机系统的底层架构中,操作系统肩负着资源管理与任务调度的重任。当我们启动各类应用程序时,其背后复杂的运作机制便悄然展开。程序,作为静态的指令集合,如何在系统中实现动态执行?本文带你一探究竟!
【Linux进程概念】—— 操作系统中的“生命体”,计算机里的“多线程”
|
5月前
|
Linux 程序员 API
CentOS如何使用Pthread线程库
这就是在CentOS下使用Pthread线程库的全过程。可见,即使是复杂的并发编程,只要掌握了基本的知识与工具,就能够游刃有余。让我们积极拥抱并发编程的魅力,编写出高效且健壮的代码吧!
108 11
|
9月前
|
并行计算 安全 Java
Python GIL(全局解释器锁)机制对多线程性能影响的深度分析
在Python开发中,GIL(全局解释器锁)一直备受关注。本文基于CPython解释器,探讨GIL的技术本质及其对程序性能的影响。GIL确保同一时刻只有一个线程执行代码,以保护内存管理的安全性,但也限制了多线程并行计算的效率。文章分析了GIL的必要性、局限性,并介绍了多进程、异步编程等替代方案。尽管Python 3.13计划移除GIL,但该特性至少要到2028年才会默认禁用,因此理解GIL仍至关重要。
603 16
Python GIL(全局解释器锁)机制对多线程性能影响的深度分析
|
10月前
|
调度 开发者
核心概念解析:进程与线程的对比分析
在操作系统和计算机编程领域,进程和线程是两个基本而核心的概念。它们是程序执行和资源管理的基础,但它们之间存在显著的差异。本文将深入探讨进程与线程的区别,并分析它们在现代软件开发中的应用和重要性。
385 4
|
11月前
|
供应链 安全 NoSQL
PHP 互斥锁:如何确保代码的线程安全?
在多线程和高并发环境中,确保代码段互斥执行至关重要。本文介绍了 PHP 互斥锁库 `wise-locksmith`,它提供多种锁机制(如文件锁、分布式锁等),有效解决线程安全问题,特别适用于电商平台库存管理等场景。通过 Composer 安装后,开发者可以利用该库确保在高并发下数据的一致性和安全性。
161 6
|
10月前
|
Java 关系型数据库 MySQL
【JavaEE“多线程进阶”】——各种“锁”大总结
乐/悲观锁,轻/重量级锁,自旋锁,挂起等待锁,普通互斥锁,读写锁,公不公平锁,可不可重入锁,synchronized加锁三阶段过程,锁消除,锁粗化
|
Java 应用服务中间件 测试技术
Java21虚拟线程:我的锁去哪儿了?
【10月更文挑战第8天】
255 0

热门文章

最新文章