Java再学习——synchronized与volatile

volatile:只保证共享资源的可见性的,任何修改都写在主存,所有线程马上就能看到,适用于新值不依赖于旧值的情形。

synchronized:保证可操作的原子性一致性和可见性。

volatile和synchronized的区别:

  volatile仅仅使变量在值发生改变时能尽快地让其他线程知道,并不能保证多线程的执行有序性。而synchronized则是锁定当前变量,只有当前线程可以访问该变量,其他线程被阻塞住。

  volatile仅能实现变量的修改可见性但不具备原子特性,而synchronized则可以保证变量的修改可见性和原子性.

  volatile不会造成线程的阻塞,而synchronized可能会造成线程的阻塞.

  volatile标记的变量不会被编译器优化,而synchronized标记的变量可以被编译器优化.

附录:

  1、当一个线程进入某个对象的一个实例的synchronized方法后,其它线程就不可以访问该方法了,但是可以同时访问这个对象的非同步方法

  2、Lock 和 synchronized 的区别 —— lock必须要在使用后释放,一般在 finally 块中释放。否则,如果受保护的代码将抛出异常,锁就有可能永远得不到释放。

时间: 2024-10-10 02:20:01

Java再学习——synchronized与volatile的相关文章

Java中的synchronized、volatile、ReenTrantLock、AtomicXXX

多线程和并发性并不是什么新内容,但是 Java 语言设计中的创新之一就是,它是第一个直接把跨平台线程模型和正规的内存模型集成到语言中的主流语言.核心类库包含一个 Thread 类,可以用它来构建.启动和操纵线程,Java 语言包括了跨线程传达并发性约束的构造 -- synchronized 和 volatile .在简化与平台无关的并发类的开发的同时,它决没有使并发类的编写工作变得更繁琐,只是使它变得更容易了. synchronized 快速回顾 把代码块声明为 synchronized,有两个

Java再学习——随机面试题

1.final, finally, finalize的区别 final—是修饰符,可以修饰变量.方法和类. final类不能再派生出新的子类即不可当父类: final变量必须在声明时给定初值或在构造方法中赋值,在以后的引用中只能读取,不可修改. final方法不能重载. finally—在异常处理时提供 finally 块来执行收尾操作.如果抛出一个异常,那么相匹配的 catch 子句就会执行,而finally则是只要try代码块有执行(无论return与否),最后都会进入到 finally 块

Java语法细节 - synchronized和volatile

目录 synchronized关键字 关键字volatile synchronized关键字 synchronized关键字锁住方法和this的不同之处: public synchronized void MyMethod() { /** * 1 注意,如果synchronized的是TestClass.class,那么任何new出来的该类的实例都会被阻塞,该方法对于该类的所有实例都是一个临界区 * 2 如果synchronized的是this,那么只是针对于一个类的具体实例来说,并不是所有的

Java再学习——CopyOnWrite容器

一,定义 CopyOnWrite容器即写时复制的容器.通俗的理解是当我们往一个容器添加元素的时候,不直接往当前容器添加,而是先将当前容器进行Copy,复制出一个新的容器,然后新的容器里添加元素,添加完元素之后,再将原容器的引用指向新的容器.这样做的好处是我们可以对CopyOnWrite容器进行并发的读,而不需要加锁,因为当前容器不会添加任何元素.所以CopyOnWrite容器也是一种读写分离的思想,读和写不同的容器.目前Java并发包里提供了两个使用CopyOnWrite机制实现的并发容器,它们

Java再学习——深究static关键字

一.static关键字的用途 可以在没有创建对象的情况下来进行(方法/变量)调用.也就是,被static关键字修饰的方法或者变量不需要依赖于对象来进行访问,只要类被加载了,就可以通过类名去进行访问. 1,static修饰方法 static方法一般称作静态方法,由于静态方法不依赖于任何对象就可以进行访问,因此对于静态方法来说,是没有this的,因为它不依附于任何对象,既然都没有对象,就谈不上this了.并且由于这个特性,在静态方法中不能访问类的非静态成员变量和非静态成员方法,因为非静态成员方法/变

Java再学习——线程之创建

Java创建线程有两种方法,一种是继承Thread,另一种实现Runnable或Callable接口. 一,继承Thread public class APP { public static void main(String[] args) { Thread thread = new Thread() { @Override public void run() { int i = 0; while (i < 100) { System.out.println(i++); try { Thread

Java再学习-JVM类加载和执行机制

  JVM简介 JVM是Java Virtual Machine(Java虚拟机)的缩写,JVM是一种用于计算设备的规范,它是一个虚构出来的计算机,是通过在实际的计算机上仿真模拟各种计算机功能来实现的.Java虚拟机包括一套字节码指令集.一组寄存器.一个栈.一个垃圾回收堆和一个存储方法域. JVM屏蔽了与具体操作系统平台相关的信息,使Java程序只需生成在Java虚拟机上运行的目标代码(字节码),就可以在多种平台上不加修改地运行.JVM在执行字节码时,实际上最终还是把字节码解释成具体平台上的机器

Java再学习-反射机制

首先说到反射,大家肯定不会陌生,如果不知道反射,相信那些市面上常用的主流框架就不会出现了.废话不说,上主题! Java反射机制 运行时 判断任意一个对象所属的类 构造任意一个类的对象 判断任意一个类所具有的成员变量和方法 调用一个对象的方法 注意点:运行时,而不是编译时 首先概念性的东西,小编就不细说了,想了解的直接问度娘吧,直接上干货吧. 通过反射来进行方法调用的具体步骤: 1.首先要获取Class对象(手段比较多,例如通过forname手段和InvokeTester.class手段) 2.如

Java再学习——栈(stack)和堆(heap)

一.内存分配的策略 按照编译原理的观点,程序运行时的内存分配有三种策略,分别是静态的,栈式的,和堆式的. 静态存储分配是指在编译时就能确定每个数据目标在运行时刻的存储空间需求,因而在编译时就可以给他们分配固定的内存空间.这种分配策略要求程序代码中不允许有可变数据结构(比如可变数组)的存在,也不允许有嵌套或者递归的结构出现,因为它们都会导致编译程序无法计算准确的存储空间需求. 栈式存储分配也可称为动态存储分配,是由一个类似于堆栈的运行栈来实现的.和静态存储分配相反,在栈式存储方案中,程序对数据区的