多线程和并发库应用五-线程间数据共享
2018-01-06 18:22
741 查看
本章主要讲述线程之间怎么实现数据共享
看下面一个例子
只用一个静态变量去存储数据然后创建两个线程分别设置值和取值发现运行结果如下
显然和预期的不一样。
改造一下将值存放在map 中
运行结果如下
源码地址:https://github.com/haha174/thread-learning.git
文章地址:http://www.haha174.top/article/details/251787
看下面一个例子
public class ThreadScopShareData { public static int data=0; public static void main(String[] args){ for (int i=0;i<2;i++) new Thread(new Runnable() { public void run() { data=new Random().nextInt(); System.out.println(Thread.currentThread().getName()+" has put data: "+data); new A().get(); new B().get(); } }).start(); } static class A{ public int get(){ System.out.println(Thread.currentThread().getName()+" has A get data: "+data); return data; } } static class B{ public int get(){ System.out.println(Thread.currentThread().getName()+" has B get data: "+data); return data; } } }
只用一个静态变量去存储数据然后创建两个线程分别设置值和取值发现运行结果如下
Thread-1 has put data: 823252219 Thread-1 has A get data: 823252219 Thread-0 has put data: 1753022753 Thread-0 has A get data: 1753022753 Thread-0 has B get data: 1753022753 Thread-1 has B get data: 1753022753
显然和预期的不一样。
改造一下将值存放在map 中
public class ThreadScopShareData { public static int data=0; static Map<String,Integer> map=new ConcurrentHashMap<String, Integer>(); public static void main(String[] args){ for (int i=0;i<2;i++) new Thread(new Runnable() { public void run() { data=new Random().nextInt(); map.put(Thread.currentThread().getName(),data); System.out.println(Thread.currentThread().getName()+" has put data: "+data); new A().get(); new B().get(); } }).start(); } static class A{ public int get(){ System.out.println(Thread.currentThread().getName()+" has A get data: "+map.get(Thread.currentThread().getName())); return map.get(Thread.currentThread().getName()); } } static class B{ public int get(){ System.out.println(Thread.currentThread().getName()+" has B get data: "+map.get(Thread.currentThread().getName())); return map.get(Thread.currentThread().getName()); } } }
运行结果如下
Thread-0 has put data: -619140736 Thread-1 has put data: 1805075629 Thread-0 has A get data: -619140736 Thread-0 has B get data: -619140736 Thread-1 has A get data: 1805075629 Thread-1 has B get data: 1805075629
源码地址:https://github.com/haha174/thread-learning.git
文章地址:http://www.haha174.top/article/details/251787
相关文章推荐
- java多线程并发库高级应用 之 多个线程之间共享数据的方式探讨
- 多线程并发库高级应用 之 线程范围内共享数据
- 多线程和并发库应用七-线程间数据共享2
- 多线程并发库高级应用 之 多个线程之间共享数据的方式探讨
- 多线程并发库高级应用 之 多个线程之间共享数据的方式探讨
- 多线程并发库高级应用 之 线程范围内共享数据
- 多线程并发库高级应用 之 线程范围内共享数据
- Java多线程与并发应用-(6)-多个线程之间共享对象和数据的方式
- 【Java多线程与并发库】7.多个线程之间共享数据的方式探讨
- java多线程与线程并发四:线程范围内的共享数据
- JAVA笔记14__多线程共享数据(同步)/ 线程死锁 / 生产者与消费者应用案例 / 线程池
- java并发-多线程之多个线程之间共享数据(6)
- Java多线程与并发库高级应用之线程数据交换Exchanger
- Java线程与并发库高级应用-线程范围内共享数据ThreadLocal类
- 【Java多线程与并发库】06 多个线程之间共享数据的方式探讨
- java多线程并发库高级应用 之 线程范围内共享数据
- 【Java多线程与并发库】7.多个线程之间共享数据的方式探讨
- java多线程与线程并发五:多个线程访问共享对象和数据的方式
- 黑马程序员--读写字节数组,随机读写流,集合IO的思维导图,多线程部分,单例设计模式,线程和进程的概念,Java中的线程的创建方式,线程的随机性,线程的状态图,多线程操作共享数据的安全性,死锁
- Java多线程/并发05、synchronized应用实例:线程间操作共享数据