您好,登录后才能下订单哦!
密码登录
登录注册
点击 登录注册 即表示同意《亿速云用户服务条款》
在Java中,多线程可以通过以下几种方式实现数据共享:
public class SharedData {
private int data;
public synchronized void setData(int data) {
this.data = data;
}
public synchronized int getData() {
return data;
}
}
import java.util.concurrent.ConcurrentHashMap;
public class SharedData {
private ConcurrentHashMap<String, Integer> dataMap = new ConcurrentHashMap<>();
public void setData(String key, Integer value) {
dataMap.put(key, value);
}
public Integer getData(String key) {
return dataMap.get(key);
}
}
import java.util.concurrent.atomic.AtomicInteger;
public class SharedData {
private AtomicInteger data = new AtomicInteger(0);
public void incrementData() {
data.incrementAndGet();
}
public int getData() {
return data.get();
}
}
public class SharedData {
private int data;
private boolean isReady = false;
public synchronized void setData(int data) {
this.data = data;
isReady = true;
notifyAll();
}
public synchronized int getData() throws InterruptedException {
while (!isReady) {
wait();
}
return data;
}
}
在实际应用中,可以根据具体需求选择合适的方式来实现在Java多线程环境下的数据共享。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。