二、关于多线程并发环境下,数据安全问题
一、什么时候数据在多线程并发的环境下会存在安全问题
1.多线程并发
2.有共享数据
3.共享数据有修改行为
二、如何解决线程安全问题
当多线程并发的环境下,有共享数据,并且这个数据还会被修改,此时就存在线程安全问题,解决办法:线程排队执行(不能并发)。用排队执行解决线程安全问题,这种机制被称为线程同步机制。此时会牺牲一部分效率
三、同步编程模型和异步编程模型
异步编程模型:线程A和线程B,各自执行各自的,A不需要等待B,B也不需要等待A。其实就是多线程并发(效率较高)
同步编程模型:线程A和线程B,在线程A执行的时候必须等待线程B的执行,或者在线程B执行的时候必须等待线程A的执行结束,两个线程之间发生了等待关系,这就是同步编程模型,效率较低,线程排队执行
四、Java中的三大变量
实例变量:在堆内存中
静态变量:在方法区中
局部变量:在栈内存中
以上三大变量中局部变量永远不会存在线程安全问题,因为局部变量不共享,实例变量和静态变量,一个在堆内存中一个在方法区中,堆和方法区都是多线程共享的,所以可能存在线程安全问题
五、如何解决线程安全问题
使用synchronized(共享的对象){
同步线程代码块
}
六、在实例方法上可以使用synchronized,并且出现在实例方法上,一定锁的是this,不能是其他对象所以这种方式不灵活。另外还有一个缺点:synchronized出现在实例方法上表示整个方法体需要同步,可能会无故扩大同步范围,导致程序执行效率降低。如果共享的对象是this,并且需要同步的代码块是整个方法体,建议使用这种方式。
synchronized出现在静态方法是类锁,不管创建了几个对象,类锁只有一把
七、ArrayList,HashMap,HashSet是非线程安全的;Vector,Hashtable是线程安全的