线程同步
产生原因:每一个线程轮番抢占资源
1、不同步问题
//多个线程同时处理数据,不同步
class MyThread implements Runnable{
private int ticket = 10;//总共是10张票
@Override
public void run() {
while (this.ticket > 0){//还有余票
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName()+"还有"+this.ticket--+"张票");
}
}
}
public class Test {
public static void main(String[] args) {
MyThread myThread = new MyThread();
new Thread(myThread,"线程1").start();
new Thread(myThread,"线程2").start();
new Thread(myThread,"线程3").start();
}
}
执行以上代码之后我们会发现,票数可能会出现负数,这种问题称为不同步操作
不同步操作的优点是:处理速度快,多个线程并发执行
同步虽然可以保证数据的完整性,但是执行速度会很慢
2、synchronized处理同步问题
使用synchronized关键字处理同步问题有两种模式:同步代码块、同步方法
I、同步代码块
//使用同步代码块,必须设置一个要锁定的对象,一般锁定当前对象:this
class MyThread implements Runnable{
private int ticket = 10;//总共是10张票
@Override
public void run() {//在方法中进行拦截
for(int i = 0; i < 10; i++){
//同一时刻,只允许一个线程进入代码块处理
synchronized (this){//为程序逻辑上锁
if(this.ticket > 0){
try {
Thread.sleep(100);//模拟网络延迟