ThreadLocal

ThreadLocal

ThreadLocal 是通过让每个线程独享自己的副本,避免了资源的竞争。
synchronized 主要用于临界资源的分配,在同一时刻限制最多只有一个线程能访问该资源。

synchronized:
作用于对象的锁:1、在方法上加锁,锁对象为当前类的实例化对象;2、为代码块加锁,锁对象为this对象;3、为代码块加锁,锁对象为我们创建的任意一个对象。不要使用非final的成员变量作为同步锁对象,因为非final成员变量可以被重新赋值,导致不同的线程使用不同的对象作为锁,达不到同步锁定的效果。
作用于类级别的锁:1、静态方法加锁,对该类所有的实例化对象生效;2、获取 .class类的引用,类级别的锁;3、使用静态对象的锁,类级别的锁

JVM内存模型和JAVA内存模型

JVM内存模型:分为五大区域,堆,方法区,虚拟机栈,本地方法栈和程序计数器;其中堆和方法区是所有线程共有的,而虚拟机栈,本地方法栈和程序计数器则是线程私有的。
在这里插入图片描述

JAVA内存模型:Java 内存模型是一种规范,定义了很多东西:
1、所有的变量都存储在主内存(Main Memory)中。
2、每个线程都有一个私有的本地内存(Local Memory),本地内存中存储了该线程以读/写共享变量的拷贝副本。
3、线程对变量的所有操作都必须在本地内存中进行,而不能直接读写主内存。
4、不同的线程之间无法直接访问对方本地内存中的变量。
在这里插入图片描述
Java 语言在遵循内存模型的基础上推出了 JMM 规范,目的是解决由于多线程通过共享内存进行通信时,存在的本地内存数据不一致、编译器会对代码指令重排序、处理器会对代码乱序执行等带来的问题。

为了更精准控制工作内存和主内存间的交互,JMM 还定义了八种操作:lock, unlock, read, load,use,assign, store, write。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值