Java ConcurrentHashMap存入引用对象时也是线程安全的
2017-03-07 12:49
453 查看
开源中国博客地址
本人小白,看到资料说ConcurrentHashMap是线程安全的,get过程不需要加锁,put是线程安全的,推荐高并发时使用.但是本人不清楚是否该map中存入的引用类型对象,对象属性变化也是否线程安全的,看了很多资料,貌似都没说明这一点,所以写代码测试一下,
结果如下:
线程1:1
线程1:2
线程1:3
线程1:4
线程1:5
线程1:6
线程1:7
线程1:8
线程1:9
线程1:10
线程1:11
线程1:12
线程1:13
......省略
线程1:100
线程2:101
......省略
线程2:101
线程2:101
通过结果可以知道其存入的元素哪怕是引用类型对象,也是线程安全的
本人小白,看到资料说ConcurrentHashMap是线程安全的,get过程不需要加锁,put是线程安全的,推荐高并发时使用.但是本人不清楚是否该map中存入的引用类型对象,对象属性变化也是否线程安全的,看了很多资料,貌似都没说明这一点,所以写代码测试一下,
package testConcurrentHashMap; import java.util.concurrent.ConcurrentHashMap; /** * Created by xuzimian on 17-3-1. */ public class testConcurrentHashMap { public ConcurrentHashMap<String,TestModel> map=new ConcurrentHashMap(); public void testFunc(){ map.put("test",new TestModel(1)); Thread thread = new Thread() { @Override public void run() { int n=0; while (n<100){ System.out.println("线程1" + ":" + map.get("test"). getValue()); map.get("test").setValue(map.get("test").getValue()+1); n++; //ConcurrentUtils.sleep(10); try { Thread.sleep(60); } catch (InterruptedException e) { e.printStackTrace(); } } } }; thread.run(); Thread thread1 = new Thread() { @Override public void run() { int n = 0; while(n<100) { System.out.println("线程2" + ":" + map.get("test"). getValue()); n++; ConcurrentUtils.sleep(1); } } }; thread1.run(); } }
结果如下:
线程1:1
线程1:2
线程1:3
线程1:4
线程1:5
线程1:6
线程1:7
线程1:8
线程1:9
线程1:10
线程1:11
线程1:12
线程1:13
......省略
线程1:100
线程2:101
......省略
线程2:101
线程2:101
通过结果可以知道其存入的元素哪怕是引用类型对象,也是线程安全的
相关文章推荐
- Java ConcurrentHashMap存入引用对象时也是线程安全的
- Java ConcurrentHashMap存入引用对象时也是线程安全的
- 利用java.util.concurrent.atomic原子性对象管理类让线程安全
- [转载]java.util.concurrent.ConcurrentHashMap 如何在不损失线程安全的同时提供更高的并发性
- java对象和引用--HASHMAP
- java传递是引用的拷贝,既不是引用本身,更不是对象
- Java对象及其引用
- JAVA中的指针,引用及对象的clone
- 2006-07-28 Java的常用包,"=="和"equals"的用法,基本数据类型与引用类型,对象的克隆
- 详解Java中的指针、引用及对象的clone
- Java对象及其引用
- Java对象及其引用
- JAVA中的指针,引用及对象的clone
- JAVA基础——对象与引用概念(转载)
- Java对象及其引用
- Java对象及其引用
- [转载]JAVA中的指针,引用及对象的clone
- Java对象引用
- JAVA消除过期的对象引用
- Java对象及其引用