「java原子饮用」java原子操作
今天给各位分享java原子饮用的知识,其中也会对java原子操作进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!
本文目录一览:
- 1、什么是原子操作,java中的原子操作是什么
- 2、Java是怎么保证原子性,可见性
- 3、Java数据类型分为:原子类型和引用类型,我想问一下,原子类型中char类型如何转化为String类型(不用强制
- 4、在java中,什么是原子性
- 5、Java中如何实现原子操作
什么是原子操作,java中的原子操作是什么
"原子操作(atomic
operation)是不需要synchronized",这是Java多线程编程的老生常谈了。所谓原子操作是指不会被线程调度机制打断的操作;这种操作一旦开始,就一直运行到结束,中间不会有任何
context
switch
(切[1]
换到另一个线程)。
Java是怎么保证原子性,可见性
首先,要知道原子性和可见性是在并发环境需要思考的问题,所以下面的回答是围绕了并发场景来描述的。
如果大家不明白并发场景,请先了解java并发
原子性,可以理解为CPU层面不能分割的操作,那么 i++是原子操作吗?不是的,实际它是i=i+1,这个操作首先要读取i的值,然后为i值加1。是需要拆分的。非原子操作都会存在线程安全问题,需要我们使用同步技术(sychronized)来让它变成一个原子操作。有好几种方式实现一个原子操作。java提供了 sychronized代码块,lock接口(它的实现重入锁是比较常用的)。还可以使用原子数据结构。AtomicInteger、AtomicLong、AtomicReference等。
可见性。可以理解为线程层面各个线程之间对某个操作是透明的,各个线程可以及时知道引用的改变。volatile修饰的变量可以保证可见性,假如,一个变量只有 1或者0两种情况。那么volatile修饰之后,就不需要对这个变量加同步操作了。强调一下。volatile不能保证原子性。volatile修饰的整数i,在多线程下 i++之后,不能得到预期的值
Java数据类型分为:原子类型和引用类型,我想问一下,原子类型中char类型如何转化为String类型(不用强制
他们之间是不能转换的。String底层本来就是用Char实现的。可以看String的源码。
在java中,什么是原子性
:原子性,就是不会有中间状态存在,要么什么都没改变,要么全都改变。不会有一部分没改变,一部分改变了。 引用赋值,或者说所有赋值操作都不是原子性的。 对应的原子类是AtomicReferenc。类似的也有AtomicLong之类的原子类,来保证赋值的原子性
Java中如何实现原子操作
Java中的原子操作包括:
1)除long和double之外的基本类型的赋值操作
2)所有引用reference的赋值操作
3)java.concurrent.Atomic.* 包中所有类的一切操作
count++不是原子操作,是3个原子操作组合
1.读取主存中的count值,赋值给一个局部成员变量tmp
2.tmp+1
3.将tmp赋值给count
可能会出现线程1运行到第2步的时候,tmp值为1;这时CPU调度切换到线程2执行完毕,count值为1;切换到线程1,继续执行第3步,count被赋值为1------------结果就是两个线程执行完毕,count的值只加了1;
还有一点要注意,如果使用AtomicInteger.set(AtomicInteger.get() + 1),会和上述情况一样有并发问题,要使用AtomicInteger.getAndIncrement()才可以避免并发问题
关于java原子饮用和java原子操作的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。