程序举例:

代码:

  1. package com.synch;
  2. public class SynchronizedDemo {
  3. //共享变量
  4. private boolean ready = false;
  5. private int result = 0;
  6. private int number = 1;
  7. //写操作
  8. public synchronized void write(){
  9. ready = true;
  10. number = 2;
  11. }
  12. //读操作
  13. public synchronized void read(){
  14. if(ready){
  15. result = number*3;
  16. }
  17. System.out.println("result的值为:" + result);
  18. }
  19. //内部线程类
  20. private class ReadWriteThread extends Thread {
  21. //根据构造方法中传入的flag参数,确定线程执行读操作还是写操作
  22. private boolean flag;
  23. public ReadWriteThread(boolean flag){
  24. this.flag = flag;
  25. }
  26. @Override
  27. public void run() {
  28. if(flag){
  29. //构造方法中传入true,执行写操作
  30. write();
  31. }else{
  32. //构造方法中传入false,执行读操作
  33. read();
  34. }
  35. }
  36. }
  37. public static void main(String[] args)  {
  38. SynchronizedDemo synDemo = new SynchronizedDemo();
  39. //启动线程执行写操作
  40. synDemo .new ReadWriteThread(true).start();
  41. //      try {
  42. //          Thread.sleep(1000);
  43. //      } catch (InterruptedException e) {
  44. //          // TODO Auto-generated catch block
  45. //          e.printStackTrace();
  46. //      }
  47. //启动线程执行读操作
  48. synDemo.new ReadWriteThread(false).start();
  49. }
  50. }

代码示例:

  1. package com.synch;
  2. import java.util.concurrent.locks.Lock;
  3. import java.util.concurrent.locks.ReentrantLock;
  4. public class VolatileDemo {
  5. private Lock lock = new ReentrantLock();
  6. private int number = 0;
  7. public int getNumber(){
  8. return this.number;
  9. }
  10. public void increase(){
  11. try {
  12. Thread.sleep(100);
  13. } catch (InterruptedException e) {
  14. // TODO Auto-generated catch block
  15. e.printStackTrace();
  16. }
  17. lock.lock();
  18. try {
  19. this.number++;
  20. } finally {
  21. lock.unlock();
  22. }
  23. }
  24. /**
  25. * @param args
  26. */
  27. public static void main(String[] args) {
  28. // TODO Auto-generated method stub
  29. final VolatileDemo volDemo = new VolatileDemo();
  30. for(int i = 0 ; i < 500 ; i++){
  31. new Thread(new Runnable() {
  32. @Override
  33. public void run() {
  34. volDemo.increase();
  35. }
  36. }).start();
  37. }
  38. //如果还有子线程在运行,主线程就让出CPU资源,
  39. //直到所有的子线程都运行完了,主线程再继续往下执行
  40. while(Thread.activeCount() > 1){//让所有的子线程都执行完后,然后再执行<pre name="code" class="java">//System.out.println("number : " + volDemo.getNumber());   语句。因为主线程算一个。当活跃线程为1时,也就是所有的子线程执行完毕了。此///时退出while 循环执行输出语句。

Thread.yield();}System.out.println("number : " + volDemo.getNumber());}}



Java多线程之可见性与原子性——synchronized VS volatile的更多相关文章

  1. java并发之可见性与原子性:Syncronized和volatile

    转载:http://blog.csdn.net/guyuealian/article/details/52525724 在说明Java多线程内存可见性之前,先来简单了解一下Java内存模型.     ...

  2. Java多线程学习(二)synchronized关键字(2)

    转载请备注地址:https://blog.csdn.net/qq_34337272/article/details/79670775 系列文章传送门: Java多线程学习(一)Java多线程入门 Ja ...

  3. Java多线程学习(二)synchronized关键字(1)

    转载请备注地址: https://blog.csdn.net/qq_34337272/article/details/79655194 Java多线程学习(二)将分为两篇文章介绍synchronize ...

  4. Java多线程中提到的原子性和可见性、有序性

    1.原子性(Atomicity)   原子性是指在一个操作中就是cpu不可以在中途暂停然后再调度,既不被中断操作,要不执行完成,要不就不执行. 如果一个操作时原子性的,那么多线程并发的情况下,就不会出 ...

  5. java多线程补:充原子性和可见性

    参考:http://www.cnblogs.com/mengyan/archive/2012/08/22/2651575.html 原子性:所谓原子性就是不可分割的,比如:在我们编程中直接给变量赋值, ...

  6. Java-JUC(二):Java内存模型可见性、原子性、有序性及volatile具有特性

    1.Java HotSpot JVM运行时数据区 Java内存模型即Java Memory Model,简称JMM.JMM定义了Java 虚拟机(JVM)在计算机内存(RAM)中的工作方式.JVM是整 ...

  7. java线程-java多线程之可见性

    可见性:一个线程对共享变量值的修改,能够及时呗其他线程看到. 共享变量:如果一个变量在多个线程的内存中都存在副本,那么这个变量就是这几个线程的共享变量. java内存模型(JMM) 描述了java程序 ...

  8. JAVA多线程基础学习二:synchronized

    本篇主要介绍Java多线程中的同步,也就是如何在Java语言中写出线程安全的程序,如何在Java语言中解决非线程安全的相关问题,没错就是使用synchronized. 一.如何解决线程安全问题? 一般 ...

  9. Java线程(二):线程同步synchronized和volatile

    上篇通过一个简单的例子说明了线程安全与不安全,在例子中不安全的情况下输出的结果恰好是逐个递增的(其实是巧合,多运行几次,会产生不同的输出结果),为什么会产生这样的结果呢,因为建立的Count对象是线程 ...

随机推荐

  1. Vagrant (2) —— 基本安装与配置(下)

    Vagrant (2) -- 基本安装与配置(下) 摘要 基本安装与配置 版本 Vagrant版本: 1.8.1 内容 预置 我们可以通SSH登录然后安装一个web服务器,但是这样每个使用Vagran ...

  2. QPushButton取消按压后文字下沉效果

    1.下沉原因 1.1.QPushButton源码 void QPushButton::initStyleOption(QStyleOptionButton *option) const { if (d ...

  3. ansible playbook对错误的处理

    Topics Playbooks 中的错误处理 忽略错误的命令 控制对失败的定义 覆写更改结果 Ansible 通常默认会确保检测模块和命令的返回码并且会快速失败 – 专注于一个错误除非你另作打算. ...

  4. Repeater 嵌套,子级Repeater获取 父级Repeater 中的值

    第一种方法,子级Repeater中绑定父级的某个字段: <%# DataBinder.Eval((Container.NamingContainer.NamingContainer as Rep ...

  5. 【linux】——一个小程序

    利用工作之余为小伙伴写了份作业,关于进程间通信的.题目如下: 父进程从键盘上接受1000个数据,对其求和sum1,子进程对这1000个数平方和sum2,结果传给父进程,父进程将sum1+sum2后,打 ...

  6. 【jquery】fancybox 是一款优秀的 jquery 弹出层展示插件

    今天给大家分享一款优秀的 jquery 弹出层展示插件 fancybox.它除了能够展示图片之外,还可以展示 flash.iframe 内容.html 文本以及 ajax 调用,我们可以通过 css ...

  7. 添加相应型号和头文件到Keil中

  8. [hadoop读书笔记] 第十五章 sqoop1.4.6小实验 - 将mysq数据导入HBASE

    导入命令 sqoop import --connect jdbc:mysql://192.168.200.250:3306/sqoop --table widgets --hbase-create-t ...

  9. [kafka] 002_kafka_相关术语详细解析

    参考: http://www.cnblogs.com/likehua/p/3999538.html http://kafka.apache.org/documentation.html#getting ...

  10. QTcpSocket 发送和接收数据的几种方法

    1.QTcpSocket 继承于QAbstractSocket继承于QIODevice 2.QTcpSocket 提供的几种接收和发送数据方法 write ( const char *, qint64 ...