线程的运行是与当前CPU的资源调度与时间片是有关系的,当一个线程中的执行到某一部分方法的时候轮到另外一个线程来执行相应的代码,所以还没有等到第一个线程执行完那么CPU有切换到另外一个线程来运行其相应的代码,所以这个时候假如操作公共的数据部分就会出现错误
为了解决这个问题,可以使用 synchronized 同步代码块来对公共部分进行同步操作
在用synchronize关键字修饰同步代码块时,运行代码发现不能交替卖票。 以下是初始代码
package com.itheima.Test;
public class Test1a {
public static void main(String[] args) {
Ticket1a t1=new Ticket1a();
new Thread(t1,"A").start();
new Thread(t1,"B").start();
new Thread(t1,"C").start();
}
}
class Ticket1a implements Runnable{
int ticket=100;
@Override
public void run() {
synchronized (Ticket1a.class) {
while (true) {
if (ticket<=0) {
break;
}
try {
Thread.sleep(20);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName()+" sold "+(ticket--));
}
}
}
}
运行结果:
A sold 100
A sold 99
A sold 98
A sold 97
A sold 96
A sold 95
A sold 94
A sold 93
A sold 92
A sold 91
.
.
.
A sold 10
A sold 9
A sold 8
A sold 7
A sold 6
A sold 5
A sold 4
A sold 3
A sold 2
A sold 1
虽然解决了线程的安全问题,但是不能实现三个窗口交替卖票。后来仔细一看,是synchronize关键字修饰的代码块位置不对,相当于修饰了同步方法。
更改后:
@Override
public void run() {
while (true) {
synchronized (Ticket1a.class) {
if (ticket<=0) {
break;
}
try {
Thread.sleep(20);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName()+" sold "+(ticket--));
}
}
}
这样就完成了线程安全的小测试。
总结
篇幅有限!篇幅有限!关于Java synchronize线程安全测试,就聊到这儿啦…啦…啦…
以上小编所介绍的全部相关的笔记资料都已整理成册,不论是Redis面试+Redis实战pdf,还是MongDB快速上手+MongDB集群安全等手写pdf笔记,想白嫖都很so easy!!
——如果你get到了,那就点个赞转发支持一波吧!
——整理不易,白嫖私信我领取源码学习资料,100%回复分享!
——也可以添加小助手VX:xcw18874131605获取源码学习资料哦
——祝前程似锦,offer不断,好好学习,天天向上!