标签:java String Thread 读写 线程 key println tempInt 第四章
理论:
未使用读写锁的代码:
package com.javaliao.backstage;
import java.util.HashMap;
import java.util.Map;
class Data{
private volatile Map map = new HashMap<String,Object>();
//写
public void put(String key,Object value){
System.out.println(Thread.currentThread().getName()+"\t 正在写入:"+key);
try {
Thread.sleep(300);
map.put(key,value);
System.out.println(Thread.currentThread().getName()+"\t 写入完成");
} catch (InterruptedException e) {
e.printStackTrace();
}
}
//读
public void get(String key){
System.out.println(Thread.currentThread().getName()+"\t 正在读取");
try {
Thread.sleep(300);
Object value = map.get(key);
System.out.println(Thread.currentThread().getName()+"\t 读取完成:"+value);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
public class Demo {
public static void main(String[] args) {
Data data = new Data();
//五个写的线程
for (int i = 0; i < 5; i++) {
final int tempInt = i;
new Thread(()->{
data.put(tempInt+"",tempInt+"");
},String.valueOf(i)).start();
}
//五个读的线程
for (int i = 0; i < 5; i++) {
final int tempInt = i;
new Thread(()->{
data.get(tempInt+"");
},String.valueOf(i)).start();
}
}
}
控制台:
可以看到写的操作原子性和独占性没有得到保证,0线程正在写入共享资源的时候,其他线程有写入和读取的共享资源操作,导致数据不一致。
是否可以添加Lock锁解决原子性和独占性的问题?
更多内容请见原文,原文转载自:https://blog.csdn.net/weixin_44519496/article/details/120323364
标签:java,String,Thread,读写,线程,key,println,tempInt,第四章 来源: https://www.cnblogs.com/wangchuanxinshi/p/16661141.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。