使用Runnable实现数据共享

 更新时间:2018年07月18日 10:32:22   作者:NewUser2771894007  
这篇文章主要为大家详细介绍了如何使用Runnable实现数据共享,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

使用Runnable实现数据共享,供大家参考,具体内容如下

先上代码:

public class TestThread {
  private static final Logger logger = LoggerFactory.getLogger(TestThread.class);

  private final class MyRunnable implements Runnable {
    private int i;
    public MyRunnable() {
      this.i = 10;
    }
    public void run() {
      while(i > 0) {
        synchronized (this) {
          if (i > 0) {
            i--;
            logger.debug("{} buy one ticket, {} left. ", Thread.currentThread().getName(), i);
          }
        }
      }
    }
  }

  @Test
  public void testRunable() throws InterruptedException{
    MyRunnable myRunnable = new MyRunnable();
    Thread th1 = new Thread(myRunnable);
    Thread th2 = new Thread(myRunnable);
    th1.start();
    th2.start();
    th1.join();
    th2.join();
  }
}

楼上的代码很简单,模拟一个售票系统。通过两个Thread对象开启两条线程同时运行一个MyRunnable实例。

几个注意点:

1. 没有加上synchronised关键词的话,即

public void run() {
      while(i > 0) {
        if (i > 0) {
          i--;
          logger.debug("{} buy one ticket, {} left. ", Thread.currentThread().getName(), i);
        }
      }
    }

系统的运行结果:

Thread-1 buy one ticket, 8 left. 
Thread-2 buy one ticket, 8 left. 
Thread-2 buy one ticket, 6 left. 
Thread-1 buy one ticket, 6 left. 
Thread-2 buy one ticket, 5 left. 
Thread-1 buy one ticket, 4 left. 
Thread-2 buy one ticket, 3 left. 
Thread-1 buy one ticket, 2 left. 
Thread-2 buy one ticket, 1 left. 
Thread-1 buy one ticket, 0 left. 

可以看到,缺少同步的程序输出明显有问题。

2. 在进入同步代码块之后,还需要对i的值再进行一次判断,即,如果不加if判断:

public void run() {
      while(i > 0) {
        synchronized (this) {
          i--;
          logger.debug("{} buy one ticket, {} left. ", Thread.currentThread().getName(), i);

        }
      }
    }

程序的运行结果为:

Thread-2 buy one ticket, 9 left. 
Thread-2 buy one ticket, 8 left. 
Thread-2 buy one ticket, 7 left. 
Thread-2 buy one ticket, 6 left. 
Thread-2 buy one ticket, 5 left. 
Thread-2 buy one ticket, 4 left. 
Thread-2 buy one ticket, 3 left. 
Thread-2 buy one ticket, 2 left. 
Thread-2 buy one ticket, 1 left. 
Thread-2 buy one ticket, 0 left. 
Thread-1 buy one ticket, -1 left. 

可以看出,出现了“多卖”的现象, 所以需要在进入同步代码块中再进行一次if判断。

总结

synchronised用于互斥访问共享变量, 并在同步代码块中使用if判断更新共享变量。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

您可能感兴趣的文章:

相关文章

  • spring security认证异常后返回中文提示的问题

    spring security认证异常后返回中文提示的问题

    这篇文章主要介绍了spring security认证异常后返回中文提示的问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-02-02
  • Java中数组的定义与使用

    Java中数组的定义与使用

    下面小编就为大家带来一篇java中数组的定义与使用小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2021-10-10
  • springboot项目以jar包运行的操作方法

    springboot项目以jar包运行的操作方法

    公司一个springboot项目本来是打war包的,突然要改为打jar包,不知所措了,纠结该如何操作呢,折腾半天终于搞定了,下面把解决方案分享给大家,对springboot打jar包方式感兴趣的朋友一起看看吧
    2021-06-06
  • Spring Boot系列教程之日志配置

    Spring Boot系列教程之日志配置

    这篇文章主要给大家介绍了关于Spring Boot系列教程之日志配置的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-11-11
  • Spring boot定时任务的原理及动态创建详解

    Spring boot定时任务的原理及动态创建详解

    这篇文章主要给大家介绍了关于Spring boot定时任务的原理及动态创建的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-03-03
  • SpringBoot基于Redis实现生成全局唯一ID的方法

    SpringBoot基于Redis实现生成全局唯一ID的方法

    在项目中生成全局唯一ID有很多好处,生成全局唯一ID有助于提高系统的可用性、数据的完整性和安全性,同时也方便数据的管理和分析,所以本文给大家介绍了SpringBoot基于Redis实现生成全局唯一ID的方法,文中有详细的代码讲解,需要的朋友可以参考下
    2023-12-12
  • java中Memcached的使用实例(包括与Spring整合)

    java中Memcached的使用实例(包括与Spring整合)

    这篇文章主要介绍了java中Memcached的使用实例(包括与Spring整合),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-07-07
  • SpringBoot使用Sharding-JDBC实现数据分片和读写分离的方法

    SpringBoot使用Sharding-JDBC实现数据分片和读写分离的方法

    本文主要介绍了SpringBoot使用Sharding-JDBC实现数据分片和读写分离,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-10-10
  • Java数据结构之HashMap源码深入分析

    Java数据结构之HashMap源码深入分析

    Java HashMap是一种基于哈希表实现的键值对存储结构,可以实现快速的数据查找和存储。它是线程不安全的,但在单线程环境中运行效率高,被广泛应用于Java开发中
    2023-04-04
  • 一文搞懂并学会使用SpringBoot的Actuator运行状态监控组件的详细教程

    一文搞懂并学会使用SpringBoot的Actuator运行状态监控组件的详细教程

    这篇文章主要介绍了一文搞懂并学会使用SpringBoot的Actuator运行状态监控组件,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-09-09

最新评论