Java 多线程------解决 实现Runnabel接口方式线程的线程安全问题 方式一:同步代码块
1 package bytezero.threadsynchronization; 2 3 /** 4 * 创建 三个窗口 买票 总票数为 100张 使用实现Runnabel接口的方式 5 * 6 * 1.问题:买票过程中,出现了重票和错票--->线程安全问题 7 * 2.问题出现的原因:当某个线程操作车票的过程中,尚未操作完成时,其他线程参与 8 * 进来,也操作车票。 9 * 3.如何解决:当一个线程在操作ticket的时候,其他线程不能参与进来,直到线程A操作 10 * 完ticket时,其他线程才可以开始操作ticket,这种情况即使线程A出现了阻塞,也不能 11 * 被改变。 12 * 4.在Java中,我们通过同步机制,来解决线程的安全问题 13 * 14 * 方式一:同步代码块 15 * synchronized(同步监视器){ 16 * //需要被同步的代码 17 * 18 * } 19 * 说明:1.操作共享数据的代码,即为需要同步的代码 --> 不能 包含 代码多了,也不能包含代码少了 20 * 2. 共享数据:多个线程共同操作的变量 比如:ticket 就是共享数据 21 * 3.同步监视器,俗称:锁。任何一个类的对象,都可以充当锁 22 * 要求:多个线程必须共用一把锁 23 * 24 * 补充:在实现 Runnable接口创建多线程的方式中,考虑使用this充当同步监视器 25 * 26 * 方式二:同步方法 27 * 28 * 29 * 30 * 5.同步的方式,解决了线程的安全问题。----好处 31 * 操作同步代码时,只能有一个线程参与,其他线程等待,相当于是一个单线程的过程, 32 * 效率低。------局限性 33 * 34 * 35 * @author Bytezero1·zhenglei! Email:420498246@qq.com 36 * create 2021-10-15 18:11 37 * 38 * 39 * 40 */ 41 42 class window2 implements Runnable{ 43 44 private int ticket = 100; //Runnable 里面共用一个 private int ticket = 100; 45 Object obj = new Object(); //唯一性 46 Dog d1 = new Dog(); 47 48 @Override 49 public void run() { 50 while(true){ 51 // 方式一 此时的this:唯一的window2的对象 用当前对象充当 52 synchronized (this){ //方式二 synchronized (d1) { 53 if (ticket > 0) { 54 55 try { 56 Thread.sleep(100); 57 } catch (InterruptedException e) { 58 e.printStackTrace(); 59 } 60 61 System.out.println(Thread.currentThread().getName() + ":买票,票号为:" + ticket); 62 ticket--; 63 } else { 64 break; 65 } 66 } 67 } 68 } 69 } 70 71 public class WindowTest2 { 72 public static void main(String[] args) { 73 window2 w2 = new window2(); //一个对象 放入了三个 构造器中,共用了 100 74 75 Thread t1 = new Thread(w2); 76 Thread t2 = new Thread(w2); 77 Thread t3 = new Thread(w2); 78 79 t1.setName("窗口一"); 80 t2.setName("窗口二"); 81 t3.setName("窗口三"); 82 83 t1.start(); 84 t2.start(); 85 t3.start(); 86 } 87 } 88 89 class Dog{ 90 91 }
...............
本文来自博客园,作者:Bytezero!,转载请注明原文链接:https://www.cnblogs.com/Bytezero/p/15417247.html