线程同步(多人过山洞)

2024-03-02 21:18
文章标签 线程 同步 山洞 多人过

本文主要是介绍线程同步(多人过山洞),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

概念:当两个或两个以上的线程需要共享资源,它们需要某种方法来确定资源在某一刻仅被一个线程占用。达到此目的的过程叫做同步(synchronization)。

同步的关键是管程(也叫信号量semaphore)的概念。管程是一个互斥独占锁定的对象,或称互斥体(mutex)。在给定的时间,仅有一个线程可以获得管程。当一个线程需要锁定,它必须进入管程。所有其他的试图进入已经锁定的管程的线程必须挂起直到第一个线程退出管程。这些其他的线程被称为等待管程。一个拥有管程的线程如果愿意的话可以再次进入相同的管程。

任何时候在多线程情况下,你有一个方法或多个方法操纵对象的内部状态,都必须用synchronized 关键字来防止状态出现竞争。一旦线程进入实例的同步方法,没有其他线程可以进入相同实例的同步方法。该实例的其他不同步方法却仍然可以被调用。

多人过山洞的实现:

package cn.thread.cave.day23;public class Cave {/*** 人过山洞:*/public synchronized void passCave(Person person){System.out.println(person.getName()+"进入山洞!");try{Thread.sleep(2000);}catch(InterruptedException e){e.printStackTrace();}System.out.println(person.getName()+"已成功通过山洞");}
}

package cn.thread.cave.day23;public class Person {private String name;/*** 构造方法*/public Person(String name){this.name=name;}/*** 设置名字    获取名字*/public String getName(){return name;}public void setName(String name){this.name=name;}
}


package cn.thread.cave.day23;public class PersonPassCave implements Runnable{Cave cave;Person person;public PersonPassCave(Cave cave,Person person){this.cave=cave;this.person=person;new Thread(this).start();//this:实现Runnable的实例}@Overridepublic void run() {cave.passCave(person);}
}

package cn.thread.cave.day23;
/** * java实现线程同步 关键字 synchronized*    同步资源是方法  *       在方法头部返回值前加上synchronized*       synchronized void callMe(){*          //*       }*       *    同步资源是语句*       synchronized(object){*          //同步语句块*       }*  编程题1.编写多线程应用程序,模拟多个人通过一个山洞。这个山洞每次只能通过一个人,每个人通过山洞的时间为5秒,随机生成10个人,同时准备过此山洞,显示每次通过山洞人的姓名。*/
public class PersonPassCaveTest {public static void main(String[] args) {Person p1 = new Person("张一");Person p2 = new Person("张二");Person p3 = new Person("张三");Person p4 = new Person("张四");Person p5 = new Person("张五");Cave cave = new Cave();PersonPassCave ppc = new PersonPassCave(cave,p1);new PersonPassCave(cave,p2);new PersonPassCave(cave,p3);new PersonPassCave(cave,p4);new PersonPassCave(cave,p5);/*** 构造方法中不用this实现Runnable的实例,写法应如下:*/
//		PersonPassCave ppc = new PersonPassCave(cave,p1);
//		Thread t1 = new Thread(ppc);
//		t1.start();//		Thread t2 = new Thread(new PersonPassCave(cave,p2));
//		t2.start();}
}



这篇关于线程同步(多人过山洞)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/767450

相关文章

Spring Boot3虚拟线程的使用步骤详解

《SpringBoot3虚拟线程的使用步骤详解》虚拟线程是Java19中引入的一个新特性,旨在通过简化线程管理来提升应用程序的并发性能,:本文主要介绍SpringBoot3虚拟线程的使用步骤,... 目录问题根源分析解决方案验证验证实验实验1:未启用keep-alive实验2:启用keep-alive扩展建

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

Java终止正在运行的线程的三种方法

《Java终止正在运行的线程的三种方法》停止一个线程意味着在任务处理完任务之前停掉正在做的操作,也就是放弃当前的操作,停止一个线程可以用Thread.stop()方法,但最好不要用它,本文给大家介绍了... 目录前言1. 停止不了的线程2. 判断线程是否停止状态3. 能停止的线程–异常法4. 在沉睡中停止5

Java捕获ThreadPoolExecutor内部线程异常的四种方法

《Java捕获ThreadPoolExecutor内部线程异常的四种方法》这篇文章主要为大家详细介绍了Java捕获ThreadPoolExecutor内部线程异常的四种方法,文中的示例代码讲解详细,感... 目录方案 1方案 2方案 3方案 4结论方案 1使用 execute + try-catch 记录

Linux搭建Mysql主从同步的教程

《Linux搭建Mysql主从同步的教程》:本文主要介绍Linux搭建Mysql主从同步的教程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux搭建mysql主从同步1.启动mysql服务2.修改Mysql主库配置文件/etc/my.cnf3.重启主库my

Spring Boot 中正确地在异步线程中使用 HttpServletRequest的方法

《SpringBoot中正确地在异步线程中使用HttpServletRequest的方法》文章讨论了在SpringBoot中如何在异步线程中正确使用HttpServletRequest的问题,... 目录前言一、问题的来源:为什么异步线程中无法访问 HttpServletRequest?1. 请求上下文与线

在 Spring Boot 中使用异步线程时的 HttpServletRequest 复用问题记录

《在SpringBoot中使用异步线程时的HttpServletRequest复用问题记录》文章讨论了在SpringBoot中使用异步线程时,由于HttpServletRequest复用导致... 目录一、问题描述:异步线程操作导致请求复用时 Cookie 解析失败1. 场景背景2. 问题根源二、问题详细分

Java中将异步调用转为同步的五种实现方法

《Java中将异步调用转为同步的五种实现方法》本文介绍了将异步调用转为同步阻塞模式的五种方法:wait/notify、ReentrantLock+Condition、Future、CountDownL... 目录异步与同步的核心区别方法一:使用wait/notify + synchronized代码示例关键

Java多线程父线程向子线程传值问题及解决

《Java多线程父线程向子线程传值问题及解决》文章总结了5种解决父子之间数据传递困扰的解决方案,包括ThreadLocal+TaskDecorator、UserUtils、CustomTaskDeco... 目录1 背景2 ThreadLocal+TaskDecorator3 RequestContextH

java父子线程之间实现共享传递数据

《java父子线程之间实现共享传递数据》本文介绍了Java中父子线程间共享传递数据的几种方法,包括ThreadLocal变量、并发集合和内存队列或消息队列,并提醒注意并发安全问题... 目录通过 ThreadLocal 变量共享数据通过并发集合共享数据通过内存队列或消息队列共享数据注意并发安全问题总结在 J