首页 > 其他分享 >多线程-线程安全前篇

多线程-线程安全前篇

时间:2022-10-17 10:36:13浏览次数:44  
标签:前篇 Thread 张票 ricket 线程 100 多线程 ticket

线程安全

如果有多个线程在同时运行 而这些线程可能会同时运行这段代码 程序每次运行结果和单线程运行的结果是一样的

而且其他的变量的值也和预期的是一样的 就像线程安全的

演示线程的安全问题:

电影院要买票 我们模拟电影院的卖票过程 本次电影的座位共100个(背场电影只能卖100张票)

我们来模拟电影院的售票窗口 实现多个窗口同时卖出 这场电影票(多个窗口一起卖这个100张票)

需要窗口 采用线程对象来模拟 需要表 Runnable接口子类来模拟

图解:

不正确的代码:

public class DemoTicket implements Runnable {
//定义一个多个线程共享的票源
private int ricket=100;
//设置线程任务:卖票
@Override
public void run() {
//使用死循环 让卖票操作重复执行
while (true){
//加入线程休眠
try {
Thread.sleep(300);
} catch (InterruptedException e) {
e.printStackTrace();
}
//先判断票是否存在
if (ricket>0){
//票存在 买票 ticket--
System.out.println(Thread.currentThread().getName()+"--->正在买第"+ricket+"张票");
ricket--;
}
}
}
}
class test06{
public static void main(String[] args) {
//创建实现类对象
DemoTicket ticket = new DemoTicket();
//实现线程执行
/*
因为有两张售票口所有要进行出售
*/
new Thread(ticket).start();
new Thread(ticket).start();
}
}

运行结果:

标签:前篇,Thread,张票,ricket,线程,100,多线程,ticket
From: https://www.cnblogs.com/shenziyi/p/16798233.html

相关文章

  • 多线程-线程安全-同步代码块
    线程安全问题产生的原理出现了线程安全问题卖票出现了重复的票图解 线程同步当我们使用多个线程访问同一个资源的时候且多个线程对资源有写的操作就容易出现线......
  • 多线程-线程安全-同步方法
    同步方法使用synchronized修饰的方法就叫做同步方法保证A线程执行该方法的时候其他线程只能在方法外等着格式:publicsynchronizedvoidmethod(){可能......
  • 多线程-线程安全问题-lock锁
    lock锁lock机制提供了比synchronized代码块和synchronized方法更广泛的锁定操作同步代码块/同步方法具有的功能lock都有除此之外更强大更体面面向对象lock隶属于jav......
  • 多线程-并发和并行和线程与进程
    并发和并行并发:指两个或者多个事件在同一个时间段内发生并行:值两个或者多个事件在同一时刻发生(同时发生) 更详细的图解:线程和进程进程基本介绍是指一个内存中运......
  • 多线程—线程
    线程的概念cpu:中央处理器对数据进行计算指挥电脑中的软件和硬件干活cpu的分类AMDInterInterCore(核心)i788664核心8线程8线程:同时执行8个任务图解: ......
  • 多线程-创建线程类
    java使用Thread类代表线程所有线程对象都必须时Thread类或者其子类的实例每个线程的作用是完成一定的任务实际上就是执行一段程序流即一端顺序执行的代码java使用线程......
  • 操作系统实验:多进程、IPC进程间通信、线程间通信
      SHANGHAI UNIVERSITY操作系统(一)实验报告 组   号第4组学号姓名20120889曹中阳实验序号实验三日期2022年9月10日......
  • 驱动开发:内核枚举驱动内线程(答疑篇)
    这篇文章比较特殊,是一篇穿插答疑文章,由于刚好在前一篇教程《驱动开发:内核枚举PspCidTable句柄表》整理了枚举句柄表的知识点,正好这个知识点能解决一个问题,事情是这样的有一......
  • Muduo库之线程
    Thread在Thread.cc中,有一个ThreadNameInitializer类,用于线程环境初始化操作:voidafterFork(){muduo::CurrentThread::t_cachedTid=0;muduo::CurrentThread:......
  • GO语言sync包与锁:限制线程对变量的访问
    原文:http://c.biancheng.net/view/4307.htmlGo语言中sync包里提供了互斥锁Mutex和读写锁RWMutex用于处理并发过程中可能出现同时两个或多个协程(或线程)读或写同一个......