线程三线程安全
对于多线程的系统来说,如果不加以限制的话,会造成数据安全等问题,对于数据安全问题会有如下问题:
1、读取脏数据 在读取数据的时候,数据被修改了,而程序读取的是修改过的或者没有修改过的,反正不是自己期望读取的数据的值。
2、数据不一致 在使用多线程进行数据处理的时候,最终得出来的数据每一次执行都不一样。
3、数据错乱 在数据的打印或者数组中,会造成数据的顺序错乱,对于关系可能会错乱。
……
对于数据的安全性,java提供了一些解决的方法:
1、使用synchronized同步关键字
2、使用volatile关键字
3、使用原子类型:原子就是要么全部成功,要么全部失败
(1)AtomicInteger整型原子类型
方法讲解:
incrementAndGet();先自增在返回
decrementAndGet();先自减在返回
getAndIncrement();先返回在自增
getAndDecrement();先返回在自减
addAndGet(num);先加num在返回
getAndAdd(num);先返回在加num
(2)AtomicBoolean布尔类型的原子类型
getAndSet(Boolean b);先获取在设置b值
(3)AtomicLong长类型的原子类型
incrementAndGet();先自增在返回
decrementAndGet();先自减在返回
getAndIncrement();先返回在自增
getAndDecrement();先返回在自减
addAndGet(num);先加num在返回
getAndAdd(num);先返回在加num
(4)AtomicIntegerArray 原子类型的整型数组
(5)AtomicLongArray 原子类型的长整型数组
原子数组操作:
set(seat,value);设置值
getAndAdd(seat, value);将seat值返回在加上value
getAndIncrement(seat);将seat值返回在自增1
4、线程安全的容器ConcurrentMap,ConcurrentHashMap等等。
……
在考虑线程的数据安全性后,还要考虑系统是否会造成死锁的,饥饿等问题。
死锁:就是在两种以上不同的线程中,同时都占用了一个资源,但是还差一个资源就可以完成任务,但是差的那个已经被别的线程占有,又不想释放自己占有的资源,这样,线程一直在等待资源,造成线程死锁。
饥饿:就是在考虑的线程优先级的时候,低优先级的线程一直不能得到执行完成而造成的现象称为饥饿。
简单代码:
AtomicIntegerArray aia = new AtomicIntegerArray(10);
for(int i=0;i<10;i++) {
aia.set(i, i+1);
}
aia.getAndAdd(9, 10);
aia.getAndIncrement(8);
for(int i=0; i<10;i++) {
System.out.println(aia.get(i));
}
原文地址:http://blog.51cto.com/xiaoshunzi/2350384