- 浏览: 398619 次
- 性别:
- 来自: 上海
文章分类
- 全部博客 (139)
- java (39)
- linux (9)
- hibernate (2)
- Spring (10)
- Struts2 (1)
- Ext (38)
- Ext + Java (5)
- Oracle (5)
- JavaScript (15)
- 开发工具 (3)
- ajax (2)
- WebSerivice+Spring (2)
- WebService+CXF (2)
- 服务器 (4)
- MQ (1)
- Apache (3)
- axis (3)
- myeclipse,maven (2)
- WebService (4)
- web (11)
- httpinvoke (1)
- 多线程 (3)
- 同步 (1)
- Servlet (2)
- css (2)
- div (2)
- html (1)
- file (2)
- 应用软件 (1)
- myEclipse10 (1)
- mysql (2)
- Extjs4 (2)
- JavaScript css (1)
- mongodb (2)
- socket (6)
- 流媒体 (5)
- 语音技术 (5)
- freeswitch (1)
最新评论
-
白天看黑夜:
Apache Mina Server 2.0 中文参考手册(带 ...
Apache Mina 学习 -
stduPanda:
引用引用[自行车在现场咨询quote]引用引用引用引用引用引用 ...
Errors running builder 'DeploymentBuilder' on project '工程名' -
鱼翔空:
maven3 导入报Plugin execution not ...
CXF自动生成wsdl与xsd文件 -
哈哈哥_Supper:
closeAction:'hide',
Extjs4 tabPanel关闭后打开 cannot read property addcls of null -
哈哈哥_Supper:
var tab1 = tabPanel.add(
...
Extjs4 tabPanel关闭后打开 cannot read property addcls of null
原文转载:http://meng-lin.iteye.com/blog/485281,在此基础上加以修改,非常感谢原作者。
J2SE 5.0提供了一组atomic class来帮助我们简化同步处理。基本工作原理是使用了同步synchronized的方法实现了对一个long, integer, 对象的增、减、赋值(更新)操作. 比如对于++运算符AtomicInteger可以将它持有的integer 能够atomic 地递增。在需要访问两个或两个以上 atomic变量的程序代码(或者是对单一的atomic变量执行两个或两个以上的操作)通常都需要被synchronize以便两者的操作能够被当作是一个atomic的单元。
对array atomic变量来说,一次只有一个索引变量可以变动,并没有功能可以对整个array做atomic化的变动。
关于Atomic的几个方法
getAndSet() : 设置新值,返回旧值.
compareAndSet(expectedValue, newValue) : 如果当前值(current value)等于期待的值(expectedValue), 则原子地更新指定值为新值(newValue), 如果更新成功,返回true, 否则返回false, 换句话可以这样说: 将原子变量设置为新的值, 但是如果从我上次看到的这个变量之后到现在被其他线程修改了(和我期望看到的值不符), 那么更新失败
对array atomic变量来说,一次只有一个索引变量可以变动,并没有功能可以对整个array做atomic化的变动。
关于Atomic的几个方法
getAndSet() : 设置新值,返回旧值.
compareAndSet(expectedValue, newValue) : 如果当前值(current value)等于期待的值(expectedValue), 则原子地更新指定值为新值(newValue), 如果更新成功,返回true, 否则返回false, 换句话可以这样说: 将原子变量设置为新的值, 但是如果从我上次看到的这个变量之后到现在被其他线程修改了(和我期望看到的值不符), 那么更新失败
AtomicInteger,一个提供原子操作的Integer的类。在Java语言中,++i和i++操作并不是线程安全的,在使用的时候,不可避免的会用到synchronized关键字。而AtomicInteger则通过一种线程安全的加减操作接口。
来看AtomicInteger提供的接口。
//获取当前的值
public final int get()
//取当前的值,并设置新的值
public final int getAndSet(int newValue)
//获取当前的值,并自增
public final int getAndIncrement()
//获取当前的值,并自减
public final int getAndDecrement()
//获取当前的值,并加上预期的值
public final int getAndAdd(int delta)
从effective java (2)中拿来的一个关于AtomicReference的一个例子:
Java代码
- public class AtomicTest {
- private int x, y;
- private enum State {
- NEW, INITIALIZING, INITIALIZED
- };
- private final AtomicReference<State> init = new AtomicReference<State>(State.NEW);
- public AtomicTest() {
- }
- public AtomicTest(int x, int y) {
- initialize(x, y);
- }
- private void initialize(int x, int y) {
- if (!init.compareAndSet(State.NEW, State.INITIALIZING)) {
- throw new IllegalStateException("initialize is error");
- }
- this.x = x;
- this.y = y;
- init.set(State.INITIALIZED);
- }
- public int getX() {
- checkInit();
- return x;
- }
- public int getY() {
- checkInit();
- return y;
- }
- private void checkInit() {
- if (init.get() == State.INITIALIZED) {
- throw new IllegalStateException("uninitialized");
- }
- }
- }
上面的例子比较容易懂, 不过貌似没什么价值, 而在实际的应用中, 我们一般采用下面的方式来使用atomic class:
Java代码
- public class CounterTest {
- AtomicInteger counter = new AtomicInteger(0);
- public int count() {
- int result;
- boolean flag;
- do {
- result = counter.get();
- // 断点
- // 单线程下, compareAndSet返回永远为true,
- // 多线程下, 在与result进行compare时, counter可能被其他线程set了新值, 这时需要重新再取一遍再比较,
- // 如果还是没有拿到最新的值, 则一直循环下去, 直到拿到最新的那个值
- flag = counter.compareAndSet(result, result + 1);
- } while (!flag);
- return result;
- }
- public static void main(String[] args) {
- final CounterTest c = new CounterTest();
- new Thread() {
- @Override
- public void run() {
- c.count();
- }
- }.start();
- new Thread() {
- @Override
- public void run() {
- c.count();
- }
- }.start();
- new Thread() {
- @Override
- public void run() {
- c.count();
- }
- }.start();
- }
- }
类似i++这样的"读-改-写"复合操作(在一个操作序列中, 后一个操作依赖前一次操作的结果), 在多线程并发处理的时候会出现问题, 因为可能一个线程修改了变量, 而另一个线程没有察觉到这样变化, 当使用原子变量之后, 则将一系列的复合操作合并为一个原子操作,从而避免这种问题, i++=>i.incrementAndGet()
原子变量只能保证对一个变量的操作是原子的, 如果有多个原子变量之间存在依赖的复合操作, 也不可能是安全的, 另外一种情况是要将更多的复合操作作为一个原子操作, 则需要使用synchronized将要作为原子操作的语句包围起来. 因为涉及到可变的共享变量(类实例成员变量)才会涉及到同步, 否则不必使用synchronized
发表评论
-
linux下查找java进程占用CPU过高原因
2018-04-03 12:35 8071. 查找进程 top查看进程占用资源情况 ... -
Apache Mina TCP/UDP功能使用说明
2017-03-14 14:18 1787Apache Mina ... -
WEB容器清除服务器缓存
2016-11-18 17:18 1333#weblogic 删除域目录中的servers/XXXS ... -
-bash: ./xxx.sh: /bin/bash^M: bad interpreter: No such file or directory
2016-09-14 14:20 666今天写了一个shell脚本,然后在执行的时候报错,脚本内容很 ... -
CentOS 在线安装FFMPEG
2016-06-29 13:48 874ffmpeg是一个重要的应用软件,用于运行与视频文件转换成不 ... -
Input File sumbit Class not found
2015-12-02 00:05 1158最近文件上传,遇到一个愚蠢问题,在form表单提交内容到ac ... -
mysql数据库相关设置linux
2013-12-04 11:11 6621.修改mysql的配置文件让其忽略表名的大小写 用r ... -
WebService CXF客户端调用样例
2013-01-04 14:48 2066如果服务端提供jar包,客户端直接引用jar ... -
ExtJS layout的9种样式风格总结
2012-12-18 10:29 1122文章转载自:http://virgoooos.iteye.co ... -
Zip文件解析(包含中文目录)
2012-12-11 13:22 2427在解析zip文件时,由于默认版本不支持中文目录,导致解析时遇到 ... -
正则表达式详解
2012-10-09 15:13 962转载自:http://edu.yesky.com/ ... -
map 排序
2012-09-28 10:44 1196用于map的值排序的方法,修改SortedSet 的方法即 ... -
java读写txt文件
2012-09-19 18:49 30035import java.io.BufferedReader; ... -
UTF-8 的bom格式处理
2012-09-14 11:54 1691一般通过httpcient请求的内容,有可能返回utf- ... -
java获取当前工程目录
2012-08-23 17:41 1690转载自:http://blog.csdn.net/yan ... -
用sax解析xml文件把读取的内容写入txt
2012-08-17 10:07 2215import java.io.BufferedWrite ... -
div+css实现圆角聊天框
2012-08-14 15:50 4835需要做个聊天样式的对话框,找了半天,终于找到一个比较好的样式, ... -
linux 启动oracle
2012-07-24 10:58 1063转载:http://www.cnitb ... -
java写excel03文件
2012-07-18 00:06 1003用java jxl写入excel03文件,下面给出一个简 ... -
JSP页面查询显示常用模式
2012-07-16 21:09 1255全文转载自:http://pharaohsprinc ...
相关推荐
5.1 AtomicInteger与AtomicLong 5.2 AtomicReference 第六章:线程池及其应用 6.1 ThreadPoolExecutor 6.2 ScheduledThreadPoolExecutor 第七章:Fork/Join框架 7.1 ForkJoinPool 等等
AtomicInteger是Java中的一个原子变量类,它可以对整型变量进行原子操作。它提供了许多有用的方法,例如get()、getAndSet()、getAndIncrement()、getAndDecrement()、getAndAdd()等。 例如,使用AtomicInteger可以...
1. java.util.concurrent - Java 并发工具包 2. 阻塞队列 BlockingQueue 3. 数组阻塞队列 ArrayBlockingQueue 4. 延迟队列 DelayQueue 5. 链阻塞队列 LinkedBlockingQueue ...25. 原子性引用型 AtomicReference
1. java.util.concurrent - Java 并发工具包 2. 阻塞队列 BlockingQueue 3. 数组阻塞队列 ArrayBlockingQueue 4. 延迟队列 DelayQueue 5. 链阻塞队列 LinkedBlockingQueue ...25. 原子性引用型 AtomicReference
为了解决这些问题,Java 5.0引入了**原子变量类**,如`AtomicInteger`、`AtomicLong`、`AtomicBoolean`和`AtomicReference`等,它们位于`java.util.concurrent.atomic`包中。这些类提供了无锁的、基于CAS操作...
本资源包含两个 pdf 文档,一本根据 Jakob Jenkov 最新博客 (http://tutorials.jenkov.com/java-util-concurrent/index.html) 整理的 java_util_concurrent_user_guide_en.pdf,一...25. 原子性引用型 AtomicReference
6. **原子变量**:分析AtomicInteger、AtomicLong和AtomicReference等原子变量类,以及它们如何实现无锁编程和高效并发操作。 7. **线程局部变量**:解释ThreadLocal类的工作原理,如何为每个线程提供独立的变量...
本资源包含两个 pdf 文档,一本根据 Jakob Jenkov 最新博客 (http://tutorials.jenkov.com/java-util-concurrent/index.html) 整理的 java_util_concurrent_user_guide_en.pdf,一...25. 原子性引用型 AtomicReference
例如,AtomicInteger、AtomicLong和AtomicReference等。原子变量的实现依赖于现代CPU提供的原子指令,如CAS(Compare-And-Swap)指令,这些指令能够确保在多线程环境下对变量的更新操作的原子性,从而避免复杂的加锁...
为了解决这个问题,Java提供了`java.util.concurrent.atomic`包下的原子类,如AtomicInteger、AtomicLong和AtomicReference等。这些原子类的更新操作由Java内存模型直接保证原子性。此外,`synchronized`关键字的...
1. AtomicInteger、AtomicLong、AtomicReference等,这些原子类提供了一些原子操作,可以用来实现原子性。 2. 这些原子类可以用来解决线程安全问题,例如,使用AtomicInteger可以实现原子性的自增操作。 五、Java中...
Java中提供了`java.util.concurrent.atomic`包,该包包含了一系列的原子类,如AtomicInteger、AtomicLong、AtomicReference等。这些类提供的原子操作主要基于硬件层面的CAS(Compare and Swap,比较并交换)指令来...
为了保证线程安全,可以采取以下几种策略:避免跨线程共享变量,使用不可变对象(final常量),使用ThreadLocal保存状态变量,控制变量的可见性(通过volatile关键字或原子变量如AtomicLong和AtomicReference等),...
1. `AtomicBoolean`, `AtomicInteger`, `AtomicLong`: 这些类分别提供了对布尔值、整型和长整型的原子操作。它们提供了`get()`, `set()`, `compareAndSet()`, `incrementAndGet()`等方法,这些方法在多线程环境下...
Atomic类,如AtomicInteger、AtomicLong和AtomicReference,提供了在不使用锁的情况下实现原子更新的能力。这些类提供了原子操作,如incrementAndGet(),decrementAndGet(),compareAndSet()等,用于在高并发环境下...
原子类如AtomicInteger、AtomicLong和AtomicReference是线程安全的变量,它们提供了一种无锁编程的方式,可以在不使用synchronized的情况下保证更新的原子性。这些类在高并发场景下能提供更好的性能。 最后,...
原子类如AtomicInteger、AtomicLong和AtomicReference等提供了一种无锁的更新机制,保证了在高并发场景下的数据一致性。它们通过CAS(Compare and Swap)操作实现原子性,避免了synchronized关键字带来的开销,提高...
这些类包括AtomicInteger、AtomicLong、AtomicReference等,它们都是通过底层的CAS操作来实现无锁线程安全访问的。例如,AtomicInteger类提供了如compareAndSet、getAndIncrement等原子操作方法,这些方法内部都使用...