マルチスレッドでの並行性の最初の理解
並行性とは:チケットグラブの例をシミュレートします
public class TextThread3 implements Runnable {
//票数
private int tickName=10;
@Override
public void run() {
while (true){
//如果票数小于10跳出循环
if(tickName<=0){
break;
}
try {
//延时操作,防止cpu将全部资源分配给同一个人
Thread.sleep(200);
} catch (InterruptedException e) {
e.printStackTrace();
}
//Thread.currentThread().getName():获取当前线程的名字
System.out.println(Thread.currentThread().getName()+"拿到了第"+tickName--+"张票");
}
}
public static void main(String[] args) {
TextThread3 textThread3=new TextThread3();
new Thread(textThread3, "小明").start();
new Thread(textThread3, "老师").start();
new Thread(textThread3, "黄牛党").start();
}
}
コードを実行すると、次のことがわかります。スレッドロックなしで、教師とXiaoMingが同時に4番目のチケットを取得しました。
解決策:スレッドロックを追加し、フラグを使用してスレッドを停止します
*フラグビットの参照がわかりません:https://blog.csdn.net/moerduo0/article/details/113803579
変更されたコード:チケットを購入するためのコードを新しいメソッドbuy()にカプセル化し、それに同期されたスレッドロックを追加します
public class TextThread3 implements Runnable {
//票数
private int tickName=10;
//标志位
boolean flag =true;
@Override
public void run() {
//当flag为false停止循环
while (flag){
try {
//买票
buy();
} catch (Exception e) {
e.printStackTrace();
}
}
}
//线程锁
private synchronized void buy() throws Exception{
//判断是否有票没配票时flag为false
if(tickName<=0){
flag=false;
return;
}
//模拟延时
Thread.sleep(100);
//买票
System.out.println(Thread.currentThread().getName()+"拿到了第"+tickName--+"张票");
}
public static void main(String[] args) {
TextThread3 textThread3=new TextThread3();
new Thread(textThread3, "小明").start();
new Thread(textThread3, "老师").start();
new Thread(textThread3, "黄牛党").start();
}
}
効果:今は正常です