synchronized 是java语言keyword。当它用来修饰一个方法或者一个代码块的时候,可以保证在同一时刻最多仅仅有一个线程运行该段代码。

synchronized keyword,它包含两种使用方法:synchronized 方法和 synchronized 块。

本文直接以代码的形式来展示 synchronized keyword的使用:

【1】synchronized  Demo1:

[html] view
plain
copy

  1. package com.andyidea.demo;
  2. /**
  3. * 当两个并发线程訪问同一个对象object中的这个synchronized(this)同步代码块时,
  4. * 一个时间内仅仅能有一个线程得到运行。还有一个线程必须等待当前线程运行完这个代码
  5. * 块以后才干运行该代码块。
  6. * @author Andy.Chen
  7. *
  8. */
  9. public class Thread01 implements Runnable {
  10. @Override
  11. public void run() {
  12. synchronized (this) {
  13. for(int i=0;i<3;i++){
  14. System.out.println(Thread.currentThread().getName()+" synchronized loop "+i);
  15. }
  16. }
  17. }
  18. public static void main(String[] args) {
  19. Thread01 t01 = new Thread01();
  20. System.out.println("synchronized keyword使用 \n"
  21. +"--------------------------");
  22. Thread ta = new Thread(t01,"A");
  23. Thread tb = new Thread(t01,"B");
  24. ta.start();
  25. tb.start();
  26. }
  27. }

执行结果例如以下:

[html] view
plain
copy

  1. synchronized keyword使用
  2. --------------------------
  3. B synchronized loop 0
  4. B synchronized loop 1
  5. B synchronized loop 2
  6. A synchronized loop 0
  7. A synchronized loop 1
  8. A synchronized loop 2

【2】synchronized  Demo2:

[html] view
plain
copy

  1. package com.andyidea.demo;
  2. /**
  3. * 当一个线程訪问object的一个synchronized(this)同步代码块时,
  4. * 还有一个线程仍然能够訪问该object中的非synchronized(this)同步代码块。
  5. * @author Andy.Chen
  6. *
  7. */
  8. public class Thread02 {
  9. public void method01(){
  10. synchronized (this) {
  11. int i=0;
  12. while(i++ < 3){
  13. System.out.println(Thread.currentThread().getName() +":"+ i);
  14. try {
  15. Thread.sleep(1000);
  16. } catch (InterruptedException e) {
  17. e.printStackTrace();
  18. }
  19. }
  20. }
  21. }
  22. public void method02(){
  23. //第1种方式:当一个线程訪问object的一个synchronized(this)同步代码块时。
  24. //还有一个线程仍然能够訪问该object中的非synchronized(this)同步代码块。
  25. //      int j=0;
  26. //      while(j++ < 3){
  27. //          System.out.println(Thread.currentThread().getName() +":"+ j);
  28. //          try {
  29. //              Thread.sleep(1000);
  30. //          } catch (InterruptedException e) {
  31. //              e.printStackTrace();
  32. //          }
  33. //      }
  34. //第2种方式:当一个线程訪问object的一个synchronized(this)同步代码块时,
  35. //其他线程对object中全部其他synchronized(this)同步代码块的訪问将被堵塞。

  36. synchronized (this) {
  37. int j=0;
  38. while(j++ < 3){
  39. System.out.println(Thread.currentThread().getName() +":"+ j);
  40. try {
  41. Thread.sleep(1000);
  42. } catch (InterruptedException e) {
  43. e.printStackTrace();
  44. }
  45. }
  46. }
  47. }
  48. /**
  49. * 当一个线程訪问object的一个synchronized(this)同步代码块时,
  50. * 它就获得了这个object的对象锁。

  51. * 结果,其他线程对该object对象全部同步代码部分的訪问都被临时堵塞。
  52. */
  53. public synchronized void method3(){
  54. int k=0;
  55. while(k++ < 3){
  56. System.out.println(Thread.currentThread().getName() +":"+ k);
  57. try {
  58. Thread.sleep(1000);
  59. } catch (InterruptedException e) {
  60. e.printStackTrace();
  61. }
  62. }
  63. }
  64. public static void main(String[] args) {
  65. final Thread02 t02 = new Thread02();
  66. System.out.println("synchronized keyword使用 \n"
  67. +"--------------------------");
  68. Thread t02A = new Thread(new Runnable() {
  69. @Override
  70. public void run() {
  71. t02.method01();
  72. }
  73. },"A");
  74. Thread t02B = new Thread(new Runnable() {
  75. @Override
  76. public void run() {
  77. t02.method02();
  78. }
  79. },"B");
  80. Thread t02C = new Thread(new Runnable() {
  81. @Override
  82. public void run() {
  83. t02.method3();
  84. }
  85. },"C");
  86. t02A.start();
  87. t02B.start();
  88. t02C.start();
  89. }
  90. }

执行结果例如以下:

[html] view
plain
copy

  1. synchronized keyword使用
  2. --------------------------
  3. B:1
  4. B:2
  5. B:3
  6. C:1
  7. C:2
  8. C:3
  9. A:1
  10. A:2
  11. A:3

【3】synchronized  Demo3:

[html] view
plain
copy

  1. package com.andyidea.demo;
  2. /**
  3. * synchronized对象锁
  4. * @author Andy.Chen
  5. *
  6. */
  7. public class Thread03 {
  8. class InnerObject{
  9. /**
  10. * 内部类方法1
  11. */
  12. private void innerMethod01(){
  13. int i=0;
  14. while(i++ < 3){
  15. System.out.println(Thread.currentThread().getName() +":"+ i);
  16. try {
  17. Thread.sleep(1000);
  18. } catch (InterruptedException e) {
  19. e.printStackTrace();
  20. }
  21. }
  22. }
  23. /**
  24. * 内部类方法2
  25. */
  26. private void innerMethod02(){
  27. int j=0;
  28. while(j++ < 3){
  29. System.out.println(Thread.currentThread().getName() +":"+ j);
  30. try {
  31. Thread.sleep(1000);
  32. } catch (InterruptedException e) {
  33. e.printStackTrace();
  34. }
  35. }
  36. }
  37. }
  38. /**
  39. * 外部类方法1
  40. * @param innerObj
  41. */
  42. private void outerMethod01(InnerObject innerObj){
  43. synchronized (innerObj) {
  44. innerObj.innerMethod01();
  45. }
  46. }
  47. /**
  48. * 外部类方法2
  49. * @param innerObj
  50. */
  51. private void outerMethod02(InnerObject innerObj){
  52. innerObj.innerMethod02();
  53. }
  54. public static void main(String[] args) {
  55. final Thread03 t03 = new Thread03();
  56. final InnerObject innerObj = t03.new InnerObject();
  57. System.out.println("synchronized keyword使用 \n"
  58. +"--------------------------");
  59. Thread t03A = new Thread(new Runnable() {
  60. @Override
  61. public void run() {
  62. t03.outerMethod01(innerObj);
  63. }
  64. },"A");
  65. Thread t03B = new Thread(new Runnable() {
  66. @Override
  67. public void run() {
  68. t03.outerMethod02(innerObj);
  69. }
  70. },"B");
  71. t03A.start();
  72. t03B.start();
  73. }
  74. }

执行结果例如以下:

[html] view
plain
copy

  1. synchronized keyword使用
  2. --------------------------
  3. A:1
  4. B:1
  5. B:2
  6. A:2
  7. B:3
  8. A:3

总结:

1.  synchronized 方法控制对类成员变量的訪问:每一个类实例相应一把锁,每一个 synchronized 方法都必须获得调用该方法的类实例的锁方能运行。否则所属线程堵塞,方法一旦运行。就独占该锁。直到从该方法返回时才将锁释放。此后被堵塞的线程方能获得该锁。又一次进入可运行状态。

这样的机制确保了同一时刻对于每一个类实例,其全部声明为 synchronized 的成员函数中至多仅仅有一个处于可运行状态(由于至多仅仅有一个可以获得该类实例相应的锁),从而有效避免了类成员变量的訪问冲突(仅仅要全部可能訪问类成员变量的方法均被声明为
synchronized)。

2. synchronized 块是这样一个代码块,当中的代码必须获得对象 syncObject (如前所述,能够是类实例或类)的锁方能运行。

因为能够针对随意代码块。且可随意指定上锁的对象。故灵活性较高。

对synchronized(this)的一些理解 

一、当两个并发线程訪问同一个对象object中的这个synchronized(this)同步代码块时。一个时间内仅仅能有一个线程得到运行。

还有一个线程必须等待当前线程运行完这个代码块以后才干运行该代码块。

二、然而。当一个线程訪问object的一个synchronized(this)同步代码块时。还有一个线程仍然能够訪问该object中的非synchronized(this)同步代码块。

三、尤其关键的是。当一个线程訪问object的一个synchronized(this)同步代码块时,其他线程对object中全部其他synchronized(this)同步代码块的訪问将被堵塞。

四、当一个线程訪问object的一个synchronized(this)同步代码块时。它就获得了这个object的对象锁。

结果,其他线程对该object对象全部同步代码部分的訪问都被临时堵塞。

Android(java)同步方法synchronized的更多相关文章

  1. Java多线程同步方法Synchronized和volatile

    11 同步方法  synchronized – 同时解决了有序性.可见性问题  volatile – 结果可见性问题 12 同步- synchronized synchronized可以在任意对象上加 ...

  2. Java同步方法:synchronized到底锁住了谁?

    目录 前言 同步方法 类的成员方法 类的静态方法 同步代码块 总结 其他同步方法 参考资料 前言 相信不少同学在上完Java课后,对于线程同步部分的实战,都会感到不知其然. 比如上课做实验的时候,按着 ...

  3. Java 多线程 —— synchronized关键字

    java 多线程 目录: Java 多线程——基础知识 Java 多线程 —— synchronized关键字 java 多线程——一个定时调度的例子 java 多线程——quartz 定时调度的例子 ...

  4. Java的synchronized关键字:同步机制总结

    JAVA中synchronized关键字能够作为函数的修饰符,也可作为函数内的语句,也就是平时说的同步方法和同步语句块.搞清楚synchronized锁定的是哪个对象,就能帮助我们设计更安全的多线程程 ...

  5. JAVA多线程synchronized详解

    Java语言的关键字,当它用来修饰一个方法或者一个代码块的时候,能够保证在同一时刻最多只有一个线程执行该段代码. 当两个并发线程访问同一个对象object中的这个synchronized(this)同 ...

  6. java中synchronized的用法详解

    记下来,很重要. Java语言的关键字,当它用来修饰一个方法或者一个代码块的时候,能够保证在同一时刻最多只有一个线程执行该段代码. 一.当两个并发线程访问同一个对象object中的这个synchron ...

  7. JAVA关键词synchronized的作用

    记下来,很重要. Java语言的关键字,当它用来修饰一个方法或者一个代码块的时候,能够保证在同一时刻最多只有一个线程执行该段代码. 一.当两个并发线程访问同一个对象object中的这个synchron ...

  8. java中synchronized的使用方法与具体解释

    Java语言的keyword.当它用来修饰一个方法或者一个代码块的时候,可以保证在同一时刻最多仅仅有一个线程运行该段代码. 一.当两个并发线程訪问同一个对象object中的这个synchronized ...

  9. Java 中 synchronized的用法详解(四种用法)

    Java语言的关键字,当它用来修饰一个方法或者一个代码块的时候,能够保证在同一时刻最多只有一个线程执行该段代码.本文给大家介绍java中 synchronized的用法,对本文感兴趣的朋友一起看看吧 ...

  10. java中 synchronized 的使用,确保异步执行某一段代码。

    最近看了个有关访问网络url和下载的例子,里面有几个synchronized的地方,系统学习下,以下内容很重要,记下来. Java语言的关键字,当它用来修饰一个方法或者一个代码块的时候,能够保证在同一 ...

随机推荐

  1. Sharepoint2013 列表的NewForm 页面添加一个 保存新建 按钮

    昨天一同事问我如何在sharepoint2013的NewForm.aspx页面上添加一个 save and new的button.实现save 和new的功能,save的功能和默认的save按钮效果一 ...

  2. Path Sum II leetcode java

    题目: Given a binary tree and a sum, find all root-to-leaf paths where each path's sum equals the give ...

  3. 【Kafka】Kafka-副本-分区设置-性能调优

    Kafka-副本-分区设置-性能调优 SparkKafkaDemo - Executors kafka replication 负载均衡_百度搜索 Kafka 高性能吞吐揭秘 - 友盟博客 - Seg ...

  4. 使用tensorflow的lstm网络进行时间序列预测

    https://blog.csdn.net/flying_sfeng/article/details/78852816 版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog. ...

  5. sql-获取指定年份指定月份的天数

    declare @年月 varchar(6) set @年月= '201803' --查询2015年2月有多少天 select day(dateadd(month,1,@年月+ '01 ')-1)

  6. 一个ActiveX control的创建过程

    创建 根据这篇文章的介绍:http://www.cnblogs.com/time-is-life/p/6354152.html 来创建,里面包含了创建的基本过程以及属性事件方法的使用. 使用: 参考文 ...

  7. 一个WEB应用的开发流程

    转载:http://www.51testing.com/html/56/n-3721856.html 先说项目开发过程中团队人员的分工协作. 一.人员安排 毕业至今的大部分项目都是独立完成,虽然也有和 ...

  8. (算法)从0到n整数中数字2出现的次数

    题目: 数出0到n(含)中数字2出现了几次. 思路: 1.暴力方法,数出每个数字包含几个2,然后累加起来. 2.分析:分别考虑数字n每一位出现2的次数,如123123: 从左往右考虑4123123: ...

  9. windows下用qemu搭建android

    1.下载Qemu for windows 版本为qemu-0.9.0-windows 2.下载qemuwith-kqemu-support 安装kqemu的目的就是为了加快qemu的子系统运行速度.在 ...

  10. 微信小程序 - 步骤条组件

    <!-- 未激活颜色: uncolor:'#ccc' 激活 active:0 数据源 data:[{},{}] 步骤条类型:type basic detail num more --> & ...