1)多线程环境下,方法内的变量是线程安全的

2)多个线程同时处理一个实例,这个实例内的变量是不安全的

3)不同线程中注入同一个类的不同实例,实例中的变量是安全的

4)Synchronized获取到的锁是对象锁,当多个线程访问同一个对象时,哪个线程先执行带Synchronized关键字的方法,哪个线程就持有该方法所属对象的锁,其他线程是等待状态

5)调用关键字Synchronized声明的方法一定是排队运行的,另外,只有共享资源的访问才需要同步化

6)一个对象内有多个Synchronized方法/块时

  A)A线程先持有object对象的锁,B线程可以以异步的方式调用object对象的非Synchronized方法

  B)A线程先持有object对象的锁,B线程如果此时调用object对象中的任一Synchronized方法,则需要等待A线程释放锁,也就是同步

7)实例中有两个变量,有一个Synchronized声明的方法,方法执行过程中,若一个变量赋值完成,一个变量未赋值完成,此时调用实例中非Synchronized方法去获取实例中两个变量的值,此时就会出现脏读,解决的办法是读取的方法上也加入Synchronized声明

8)Synchronized是对象锁,A线程获取到对象锁时,可执行被Synchronized声明的X方法,其他线程想要执行这个对象的任何被Synchronized声明的方法都得等待A释放,因为其他线程未获取到锁

9)Synchronized锁重入,在使用Synchronized时,当一个线程得到对象锁时,在此请求此对象的对象锁可以再次得到该对象的锁,一个Synchronized方法/块内部,可以调用本类的其他Synchronized方法/块(也就是说只要不释放,能够一直获取本实例的锁)

10)Synchronized不能继承,举个栗子,父类方法被Synchronized修饰,子类覆写父类的该方法,但并不带Synchronized修饰,就不会产生同步的效果

11)Synchronized代码块,肯定比Synchronized方法性能要好一些,也就是说Synchronized后面大括号,包裹的代码越少越好。当一个线程在执行Synchronized代码块时,其他线程可以执行这个代码块外部的代码

12)Synchronized代码块与Synchronized方法特性基本相同

13)任意对象都可以作为对象监视器,可以Synchronized(任意对象),优点:如果一个类中有很多个Synchronized方法,这时虽然能够实现同步,但会受到阻塞,所以影响运行效率;但如果使用同步代码块锁非this对象,则Synchronized(非this)代码块的程序与同步方法是异步的,不与其他锁this同步方法争抢this锁,可大大提高运行效率

  A)当多个线程同时执行Synchronized(X,非this)同步代码块时呈同步效果

  B)当其他线程执行X对象中Synchronized同步方法时也呈同步效果

  C)当其他线程执行X对象方法里面的Synchronized(this)时也呈同步效果

14)Synchronized可以用在static关键字之上,表示对当前类持锁,class锁。class锁可以对类的所有对象实例起作用。也就是说,对于class A来说,即便多个线程中每个线程创建一个A的实例,只要他们调用的是A中static synchronized的方法(或者static方法中的synchronized代码块),就得等着,就是同步

15)通常情况下,都不会将String作为锁对象,因为String存在一个常量池,当两个线程调用的String相等时,相当于是竞争同一个锁;另外,当锁住某个String变量时x,若同步方法内对x进行了更改,相当于锁对象就变化了,其他再来竞争锁就能竞争到,就起不到同步的效果了(需要注意的是,只要对象不变,即便对象的属性发生变更,也是同步的,String是因为其池化导致的一系列不同)

16)当一个synchronized方法中出现死循环时(永远都不会释放锁),其他调用改对象中synchronized方法的线程均会一直等下去,解决方法是尽量每个方法锁不同的对象,而不是都锁this

17)死锁,一个方法,先锁A,等一会再锁B;另一个方法,先锁B,等一会再锁A;当两个方法同时执行时,就出现死锁了。

18)volatile的主要作用是使变量在多个线程间可见。原理是强制线程从公共堆栈中获得变量的值,而不是从线程的私有堆栈中取值。(举个栗子:当JVM设置为-server模式时,为了线程运行的效率,线程一直在私有堆栈中取值,这样,在一个while(x)的循环中,就算外部将x设置为false,线程内也不会跟着改变,从而进入到死循环状态,这是就需要用到volatile关键字了。volatile主要使用的场合是在多个线程中,可以感知实例变量被改变了,并且获得最新的值使用)

19) volatile本质上解决的是私有堆栈与公共堆栈中的值不同步

20)volatile与synchronized的异同

  A)volatile是线程同步的轻量级实现,性能要比synchronized好;volatile只能修饰变量,而synchronized可以修饰方法或者代码块,synchronized还有性能提升的空间

  B)使用volatile不会产生阻塞,而使用synchronized会产生阻塞

  C)volatile保证可见性,但不保证原子性;synchronized保证原子性,间接保证可见性(一个变量只能在同步中操作完成了,才能被其他线程操作,所以叫间接)

  D)volatile解决的是变量在多个线程之间的可见性,而synchronized解决的是多个线程访问资源的同步性

21)synchronized可以保证在同一时刻,只有一个线程可以执行某一个方法或者某一代码块,它包含两个特性:互斥性和可见性。不进可以解决一个线程看到对象处于不一致状态,还可以保证进入同步方法或者同步代码块的每个线程,都看到由同一个锁保护之前的所有的修改效果。

Java-对象及变量的并发访问小结的更多相关文章

  1. Java多线程编程核心技术-第2章-对象及变量的并发访问-读书笔记

    第 2 章 对象及变量的并发访问 本章主要内容 synchronized 对象监视器为 Object 时的使用. synchronized 对象监视器为 Class 时的使用. 非线程安全是如何出现的 ...

  2. Java多线程——对象及变量的并发访问

    Java多线系列文章是Java多线程的详解介绍,对多线程还不熟悉的同学可以先去看一下我的这篇博客Java基础系列3:多线程超详细总结,这篇博客从宏观层面介绍了多线程的整体概况,接下来的几篇文章是对多线 ...

  3. Java——多线程之对象及变量的并发访问

    Java多线系列文章是Java多线程的详解介绍,对多线程还不熟悉的同学可以先去看一下我的这篇博客Java基础系列3:多线程超详细总结,这篇博客从宏观层面介绍了多线程的整体概况,接下来的几篇文章是对多线 ...

  4. Java多线程编程核心技术---对象及变量的并发访问(一)

    synchronized同步方法 "非线程安全"其实会在多个线程对同一个对象中的实例变量进行并发访问时发生,产生的后果就是"脏读",也就是渠道的数据其实是被更改 ...

  5. Java多线程编程核心技术(二)对象及变量的并发访问

    本文主要介绍Java多线程中的同步,也就是如何在Java语言中写出线程安全的程序,如何在Java语言中解决非线程安全的相关问题.阅读本文应该着重掌握如下技术点: synchronized对象监视器为O ...

  6. Java多线程编程核心 - 对象及变量的并发访问

    1.什么是“线程安全”与“非线程安全”? “非线程安全”会在多个线程对同一对象总的实例变量进行并发访问时发生,产生的后果是“脏读”,也就是取到的数据其实是被更改过的. “线程安全”是以获得的实例变量的 ...

  7. 对象及变量的并发访问(同步方法、同步代码块、对class进行加锁、线程死锁)&内部类的基本用法

    主要学习多线程的并发访问,也就是使得线程安全. 同步的单词为synchronized,异步的单词为asynchronized 同步主要就是通过锁的方式实现,一种就是隐式锁,另一种是显示锁Lock,本节 ...

  8. 对象和变量的并发访问synchronized解析以及死锁分析排查

    一.synchronized java并发编程中存在“非线程安全"问题.“非线程安全"是指发生在多个线程对同一个对象中的实例变量并发访问时,产生的”脏读“现象,使用synchron ...

  9. (二)对象以及变量的并发访问--synchronized的使用细节,用法

    具体的记录synchronized关键的各种使用方式,注意事项.感觉一步一步跟我来都可以看懂滴 大致是按照以下思路进行书写的.黑体字可以理解为结论, 1.synchronized锁的是什么? 2.sy ...

  10. 《JAVA多线程编程核心技术》 笔记:第二章:对象及变量的并发访问

    一.基本概念1.安全的变量和不安全的变量2.脏读的理解3.锁重入:4.锁释放5.死循环:二.synchronized 的理解:三.synchronized 同步方法3.1 同步方法不具有继承性.3.2 ...

随机推荐

  1. node.js官方文档解析 02—buffer 缓冲器

    Buffer 类的实例类似于整数数组,但 Buffer 的大小是固定的.且在 V8 堆外分配物理内存.Buffer 的大小在被创建时确定,且无法调整. Buffer 类在 Node.js 中是一个全局 ...

  2. HBase RegionServer Pause for hours 卡顿几小时 故障

    关键词:hbase jvm gc regionserver wal pause 背景: HBase 1.1.2 客户的hbase集群最近出现RegionServer宕机情况.跟踪了master和RS日 ...

  3. 好大一个坑: EF Core 异步读取大字符串字段比同步慢100多倍

    这两天遇到一个奇怪的问题,通过 EF/EF Core 查询数据库速度奇慢,先是在传统的 ASP.NET 项目中遇到(用的是EF6.0),后来将该项目迁移至 ASP.NET Core 也是同样的问题(用 ...

  4. 前端面试题汇总(主要为 Vue)

    前端面试题汇总 1. 谈谈你对MVVM开发模式的理解 MVVM分为Model.View.ViewModel三者. 1)Model:代表数据模型,数据和业务逻辑都在Model层中定义: 2)View:代 ...

  5. [emacs] emacs调整C代码的缩进格式等

    相比于VIM,emacs在默认配置下写C代码还真是不好用. 好多东西都要调整,其中最麻烦的就是缩进.调啊调,调了好久. 勉强形成一个配置如下: (add-hook 'c-mode-hook (lamb ...

  6. 2019年春季学期第二周作业 基础作业 请在第一周作业的基础上,继续完成:找出给定的文件中数组的最大值及其对应的最小下标(下标从0开始)。并将最大值和对应的最小下标数值写入文件。 输入: 请建立以自己英文名字命名的txt文件,并输入数组元素数值,元素值之间用逗号分隔。 输出 在不删除原有文件内容的情况下,将最大值和对应的最小下标数值写入文件

    ~~~ include<stdio.h> include<stdlib.h> int main() { FILE*fp; int i=0,max=0,j=0,maxb=0; i ...

  7. TypeScript初探

    TypeScript初探 TypeScript什么? 官方给的定义:TypeScript是一种由微软开发的自由和开源的编程语言,它是JavaScript类型的超集,可以编译成纯JavaScript,本 ...

  8. vue设置背景图片

    现在data里面定义: note: { backgroundImage: "url(" + require("../../assets/home/bigdatabak.p ...

  9. WCF部署失败

    HTTP 错误 404.3 - Not Found 由于扩展配置问题而无法提供您请求的页面.如果该页面是脚本,请添加处理程序.如果应下载文件,请添加 MIME 映射. 最可能的原因:•可能是缺少处理程 ...

  10. 包的初识和进阶&异常处理

    包 包是一种通过使用‘.模块名’来组织python模块名称空间的方式. 1. 无论是import形式还是from...import形式,凡是在导入语句中(而不是在使用时)遇到带点的,都要第一时间提高警 ...