多线程并发可能遇到问题,要遵循三个原则:可见性,原子性,有序性。
可见性:线程都有自己的工作内存,按照一定的机制更新到主存中,不同线程对同一对象进行操作,可能导致得到的数据错误。
原子性:一个操作或一系列操作,要么执行,要么全部不执行,不会被其他线程给中断。
有序性:程序的执行按照代码的先后顺序执行;在同一线程中可以是顺序执行的。
java提供了三个关键字volatile/sychronized/final来并发
final 修饰的对象不可变,无论多少个线程操作这个对象都没有关系
synchronized 锁,锁住资源,保证有序性
volatile 能保证有序性和可见性,不能保证原子性
可以使用Atomic保证其原子性
AtomicInteger count = new AtomicInteger(0);
void m(){
for(int i = 0; i < 10000; i++){
count.incrementAndGet();
}
}