📫作者简介:小明java问道之路,2022年度博客之星全国TOP3,专注于后端、中间件、计算机底层、架构设计演进与稳定性建设优化,文章内容兼具广度、深度、大厂技术方案,对待技术喜欢推理加验证,就职于知名金融公司后端高级工程师。
📫 热衷分享,喜欢原创~ 关注我会给你带来一些不一样的认知和成长。
🏆 2022博客之星TOP3 | CSDN博客专家 | 后端领域优质创作者 | CSDN内容合伙人
🏆 InfoQ(极客邦)签约作者、阿里云专家 | 签约博主、51CTO专家 | TOP红人、华为云享专家
🔥如果此文还不错的话,还请👍关注、点赞、收藏三连支持👍一下博主~
🍅 文末获取联系 🍅 👇🏻 精彩专栏推荐订阅收藏 👇🏻
专栏系列(点击解锁)
学习路线(点击解锁)
知识定位
全面讲解MySQL知识与企业级MySQL实战 🔥计算机底层原理🔥
目录
一、并发问题解决方案
解决并发编程方法分为两大类:无锁有局部变量、不可变对象、ThreadLocal、CAS,有锁有synchronized、Lock。
二、局部变量
成员变量:成员变量定义在方法外,类中;生命周期是随着对象的加载而加载,随着对象的销毁而销毁;存储在堆内存中;有默认值(基础数据都是零,char中的零是代表空字符,boolean是false,引用数据类型都是null);
局部变量:局部变量定义在方法中;生命周期是随着方法的加载而加载,随着方法的结束而结束;存储在栈内存中;是没有默认值,必须先初始化(先赋值)才能使用;
三、不可变对象
不可变对象是指一旦创建,其状态就不会改变的对象。如果对象的状态在整个历史过程中保持不变,那么无论有多少线程对它执行任何操作,它都保持不变。
四、ThreadLocal
ThreadLocal类在每个线程中都会创建一个对象,每个线程都会将该对象从主内存复制到工作内存,但从线程1和线程2复制的对象不是同一个对象,每个对象只由其中一个线程操作。在这个场景中,不存在所谓的共享变量,ThreadLocal 本质上是每个线程都有自己的副本,每个线程的副本彼此独立互不影响。