本文共 1337 字,大约阅读时间需要 4 分钟。
线程三线程安全
对于多线程的系统来说,如果不加以限制的话,会造成数据安全等问题,对于数据安全问题会有如下问题: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值返回在加上valuegetAndIncrement(seat);将seat值返回在自增14、线程安全的容器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));}转载于:https://blog.51cto.com/xiaoshunzi/2350384