首页 / JAVA / Java并发性:线程之间的共享内存
Java并发性:线程之间的共享内存
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Java并发性:线程之间的共享内存,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1085字,纯文字阅读大概需要2分钟。
内容图文
![Java并发性:线程之间的共享内存](/upload/InfoBanner/zyjiaocheng/949/d809f7cd82c84303b4766c63a3db743f.jpg)
假设我有一个Singleton类(任何类都可以获取实例):
class data
{
Color sun = "WHITE";
String luminance = "HIGH";
int age = 25;
double speed = 52.5
...
}
假设我有几个线程获得对该类的Singleton实例的引用.我试图找出一种方法来同步每个字段的获取/设置.
如果每个变量都有一个同步的getter / setter方法,则基本上将“锁定”整个类(而不是单个字段),直到设置了该方法为止.
有没有办法使这些线程仅锁定实例值而不锁定整个类?
-编辑:我为庞大的一个对象数据表示歉意.
数据实际上存储在几个类中.每个对象最多只有20-25个成员.
解决方法:
If I have a synchronized getter/setter method for each variable, then this will basically “lock” the whole class(instead of the individual field) until that method is set.
好吧,不.它将锁定整个对象,但是无论如何这可能就是您的意思了…
data has 1000+ variables …
选项1
如果您有足够的内存,则可以简单地使用Object []锁= new Object [1000];为此您获得了锁定.
public void setColor(Color newCol) {
synchronized (locks[17]) {
sun = newCol;
}
}
选项2
另一种选择是将所有字段标记为易失性.这将至少确保读写是原子执行的.
选项3
看一下java.util.concurrent.atomic package中的AtomicLong,AtomicReference,AtomicBoolean等.
内容总结
以上是互联网集市为您收集整理的Java并发性:线程之间的共享内存全部内容,希望文章能够帮你解决Java并发性:线程之间的共享内存所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。